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in ETSI SR 000 314: "Intellectual Property Rights (IPRs); Essential, or potentially Essential, IPRs notified to ETSI in 
respect of ETSI standards", which is available from the ETSI Secretariat. Latest updates are available on the ETSI Web 
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Pursuant to the ETSI IPR Policy, no investigation, including IPR searches, has been carried out by ETSI. No guarantee 
can be given as to the existence of other IPRs not referenced in ETSI SR 000 314 (or the updates on the ETSI Web 
server) which are, or may be, or may become, essential to the present document. 



Foreword 

This Technical Specification (TS) has been produced by Joint Technical Committee (JTC) Broadcast of the European 
Broadcasting Union (EBU), Comite Europeen de Normalisation ELECtrotechnique (CENELEC) and the European 
Telecommunications Standards Institute (ETSI). 

NOTE: The EBU/ETSI JTC Broadcast was established in 1990 to co-ordinate the drafting of standards in the 
specific field of broadcasting and related fields. Since 1995 the JTC Broadcast became a tripartite body 
by including in the Memorandum of Understanding also CENELEC, which is responsible for the 
standardization of radio and television receivers. The EBU is a professional association of broadcasting 
organizations whose work includes the co-ordination of its members' activities in the technical, legal, 
programme-making and programme-exchange domains. The EBU has active members in about 
60 countries in the European broadcasting area; its headquarters is in Geneva. 

European Broadcasting Union 

CH-1218 GRAND SACONNEX (Geneva) 

Switzerland 

Tel: +41 22 717 21 11 

Fax: +4122 717 24 81 

The Digital Video Broadcasting Project (DVB) is an industry-led consortium of broadcasters, manufacturers, network 
operators, software developers, regulatory bodies, content owners and others committed to designing global standards 
for the delivery of digital television and data services. DVB fosters market driven solutions that meet the needs and 
economic circumstances of broadcast industry stakeholders and consumers. DVB standards cover all aspects of digital 
television from transmission through interfacing, conditional access and interactivity for digital video, audio and data. 
The consortium came together in 1993 to provide global standardisation, interoperability and future proof 
specifications. 



Introduction 

Phase 1 of the work of the TV-Anytime Forum (TV AF) has defined key technologies for personal digital recorders 
(PDRs). DVB has adopted these specifications as the basis of support for PDRs on DVB networks. The present 
document provides an implementation of the TV-Anytime phase one on DVB transport streams in a way that enhances 
and extends existing DVB functionality. 



ETSI 



ETSI TS 102 323 V1.5.1 (2012-01) 



Scope 



The present document describes a method of supporting personal digital recorders (PDRs) in DVB broadcast networks. 
It was developed to fulfil the commercial requirements for supporting PDRs. The data types and protocols defined in 
the present document are based upon TV-Anytime phase 1 specifications [3], [4], [5] and [6]. 



References 



References are either specific (identified by date of publication and/or edition number or version number) or 
non-specific. For specific references, only the cited version applies. For non-specific references, the latest version of the 
reference document (including any amendments) applies. 

Referenced documents which are not found to be publicly available in the expected location might be found at 
http://docbox.etsi.org/Reference . 

NOTE: While any hyperlinks included in this clause were valid at the time of publication, ETSI cannot guarantee 
their long term validity. 

2.1 Normative references 

The following referenced documents are necessary for the application of the present document. 

[I] ETSI EN 300 468: "Digital Video Broadcasting (DVB); Specification for Service Information (SI) 
in DVB systems". 
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on personal storage systems ("TV-Anytime"); Part 4: Phase 1 - Content referencing". 
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[13] ISO/IEC 13818-6: "Information technology - Generic coding of moving pictures and associated 
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[16] W3C Recommendation: "XML Schema Part 2: Datatypes". 
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[22] ISO/IEC 15938-2: "Information technology - Multimedia content description interface - 

Part 2: Description definition language". 
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[24] ISO/IEC 646: "Information technology - ISO 7-bit coded character set for information 
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[29] DVB Audio Codec Classification Scheme. 

NOTE: See http ://www. dvb .org/metadata/c s/2007/AudioCodecCS . xml 

[30] DVB Video Codec Classification Scheme. 

NOTE: See http://www.dvb.org/metadata/cs/2007/VideoCodecCS.xml 

[3 1 ] ETSI TS 102 85 1 : "Digital Video Broadcasting (DVB); Uniform Resource Identifiers (URI) for 

DVB Systems". 



2.2 



Informative references 



The following referenced documents are not necessary for the application of the present document but they assist the 
user with regard to a particular subject area. 



[i.l] 



ISO/IEC 15938: "Information technology - Multimedia content description interface". 
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Definitions and abbreviations 



3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply: 
authority: for organization that creates CRIDs 

NOTE 1: Term used in TS 102 822-4 [6]. 

NOTE 2: In the present document the term CRID authority is used instead. 

broadcaster (service provider): organization which assembles a sequence of events or programmes to be delivered to 
the viewer based upon a schedule 

broadcast time: time and date on which an event is actually broadcast 

NOTE: For example, a news programme may actually start at 18:04:38.21. See also published time and scheduled 
time. 

broadcast timeline: stream of data which conveys a metadata content timeline during the broadcast of an item of 
content 

NOTE: See TS 102 823 [21], annex A. 

complete set of CRI data: single set of CRT data that carries all CRI data available for a CRID authority 

NOTE: See also set of CRI data. 

context: grouping of resolution providers for the purposes of managing the discovery of TV-Anytime information. A 
context could relate to a particular bouquet for which CRI is provided, or a network, etc. 

CRID authority: organization that creates CRIDs 

NOTE: This is termed in TS 102 822-4 [6] as simply an authority. 
CRID resolution: location resolution 

CRID result: (possibly empty) set of locators or CRIDs that a CRID resolves to 

CRI service: coherent set of CRI data provided by a resolution provider and describing one or more CRID authorities 
group CRID: CRID that resolves into other CRIDs, not locators 
leaf CRID: CRID that resolves into locators, not other CRIDs 
location resolution: process for establishing the address (location and time) of content instance(s) from a CRID 

NOTE: Sometimes termed "CRID resolution". 

locator: URI reference to the location of content 

NOTE: A locator can reference a file on the internet, an event on a DVB network, etc. For broadcast content a 
locator would include DVB service, date and time information. 

metadata content timeline: conceptual progress of time inherent in an item of content, which may be referred to by 
metadata and delivered by a broadcast timeline 

NOTE: See TS 102 823 [21], annex A. 

metadata description: collection of metadata from one or more CRID authorities that can be represented as an XML 
document instantiating the TV-Anytime schema and containing a single root element called TVAMain 

NOTE: The complete metadata description, or a subset thereof, may be carried in one metadata service or split 
across multiple metadata services. 
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metadata service: coherent set of TV-Anytime metadata either carried within a DVB object carousel and distinguished 
by a metadata_service_id or made available via an IP connection 

NOTE: See ISO/IEC 13818-1 [9]. 

promotional link: reference to material related to content currently being viewed 

published time: time and date on which a service provider publishes that an event starts 

NOTE: For example, a news programme may have a published time of 18:00. See also broadcast time and 
scheduled time. 

related material: content that is related in some way to the present content 

NOTE: For example, other events in the same series or the web-page for the current programme. 

resolution provider: body which provides location resolution 

NOTE: In TS 102 822-4 [6] this term is a synonym for the term resolving authority, a term which is not used in 
the present document. 

scheduled time: time and date on which a service provider has scheduled to start an event 

NOTE: For example, a news programme may have a scheduled time of 18:02. see also broadcast time and 
published time. 

set of CRI data: all CRI data for a single CRID authority at a single location 

NOTE: See also complete set of CRI data. 

Synchronized Auxiliary Data (SAD): data that needs to be delivered in such a way so as to ensure a fixed timing 
relationship with other linear streams within a DVB service, e.g. video and audio 

NOTE: See TS 102 823 [21]. 

timebase: data type used in TV-Anytime metadata for the purpose of referencing the metadata content timeline for an 
item of content 

NOTE: See TS 102 822-3-1 [4]. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

BAT Bouquet Association Table 

NOTE: See EN 300 468 [1]. 

BCD Binary-Coded Decimal 

BiM Binary format for Multimedia description streams 

BIOP Broadcast Inter-ORB Protocol 

CIT Content Identifier Table 

CRC Cyclic Redundancy Check 

CRI Content Referencing Information 

CRID Content Reference IDentifier 

DNS Domain Naming System 

DSI Download Server Initiate 

DSM-CC Digital Storage Media Command and Control 

NOTE: See ISO/IEC 13818-6 [13]. 

DVB Digital Video Broadcasting 

EIT Event Information Table 

IMI Instance Metadata Identifier 

IP Internet Protocol 
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MHP 


Multimedia Home Platform 


MJD 


Modified Julian Date 


MPEG 


Motion Picture Experts Group 


NIT 


Network Information Table 


NOTE: 


See ETSI EN 300 468 [I] 


ORB 


Object Request Broker 


FDR 


Personal Digital Recorder 


PES 


Packetized Elementary Stream 


NOTE: 


See ISO/IEC 13818-1 [9]. 


FID 


Packet Identifier 


PIT 


ProgramlnformationTable 


NOTE: 


SeeTS 102 822-3-1 [4]. 


PMT 


Programme Map Table 


RAR 


Resolving Authority Record 


RCT 


Related Content Table 


RNT 


RAR Notification Table 


SAD 


Synchronized Auxiliary Data 


SDT 


Service Description Table 


SI 


Service Information 


TVAJd 


TV- Anytime event identifier 


TVAF 


TV-Anytime Forum 


UML 


Unified Modelling Language 


URI 


Uniform Resource Indicator 


URL 


Uniform Resource Locator 


URN 


Uniform Resource Name 


UTC 


Co-ordinated Universal Time 


UTF 


Unicode Transformation Format 


XML 


extensible Markup Language 



Overview 



The present document defines how PDR devices can be supported using TV-Anytime phase 1 specifications on DVB 
transport streams. The TV-Anytime phase 1 specifications relevant to the present document are: 

• TS 102 822-2 "System description" [3]; 

• TS 102 822-3-1 "Metadata schemas" [4]; 

• TS 102 822-3-2 "System aspects in a uni-directional environment" [5]; 

• TS 102 822-4 "Content referencing" [6]. 

The TV-Anytime process for recording content is "search, select, acquire". Metadata is searched for the content the 
viewer wishes to record, the viewer selects the correct content and the PDR then records it. Figure 1 illustrates how this 
process is interpreted in a DVB transport stream environment. 
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Figure 1 : Overview of PDR process 

A number of interrelated technologies are defined that can be used to enable various PDR applications. Figure 2 
illustrates how the present document integrates these technologies into DVB transport streams. The main clauses of the 
present document are listed below. Each clause has a more detailed introduction as its first clause. 

a) TV-Anytime information discovery (clause 5): Defines how TV-Anytime metadata services and CRI 
services are discovered on DVB transport streams. Central to this is the resolution provider notification table 
(RNT), which lists resolution providers and the CRID authorities the resolution providers provide information 
on. The RNT and related descriptors implements the TV-Anytime RAR structure, as defined in 

TS 102 822-4 [6]. 

b) CRIDs in DVB networks (clause 6): Defines how URIs (including CRIDs) shall be encoded in the data 
structures defined in the present document. This clause also describes the rules for default authorities which 
can be used to abbreviate CRID strings, saving on bandwidth. CRIDs are defined in TS 102 822-4 [6]. 

c) Content resolution (clause 7): Defines how CRIDs shall be resolved (i.e. content resolution) in DVB 
transport streams and how this process works when more than one relevant CRI service is available. This 
clause also defines how CRI data, the information required for content resolution, shall be delivered in DVB 
transport streams. 

d) Profile of TVA metadata types (clause 8): Defines restrictions on specific parts of the TVA metadata 
schema. These restrictions are necessary to provide an integrated and self-consistent TV-Anytime toolkit on 
DVB transport streams. 

e) Delivery of metadata (clause 9): Defines how TV-Anytime metadata shall be carried on DVB transport 
streams. TV-Anytime metadata is defined in TS 102 822-3-1 [4]. Clause 9 is an implementation of 

TS 102 822-3-2 [5], which defines how TV-Anytime metadata is delivered in unidirectional environments. 
This clause includes a set of profiled metadata indices based on TS 102 822-3-2 [5]. 

f) Promotional links (clause 10): Defines a mechanism for referencing related material in a real-time manner. 
This mechanism is for providing the viewer with the opportunity to book content related to what is being 
viewed., e.g. booking a film whilst watching it being trailed. 

g) Accurate recording (clause 11): Defines how the receiver uses the different recording modes signalled in 
locators in CRI data. The different modes are intended to allow easy adoption of TV-Anytime whilst providing 
increasing functionality for more advanced broadcaster infrastructures. 

h) Extensions to DVB SI (clause 12): Defines how TV-Anytime technologies can be integrated into the DVB SI 
event information table (EIT). This allows those platforms that use the EIT to provide schedule information, to 
use TV-Anytime content resolution and metadata. 
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Figure 2: Overview of defined techinologies 



TV-Anytime information discovery 



5.1 



Introduction 



The TV-Anytime Forum has defined a rich set of content referencing information and metadata. This information may 
be carried on a broadcast network or on other networks such as an IP network. On a broadcast network metadata is 
carried in metadata services and content referencing information is carried in content referencing services. A receiver 
accessing TV-Anytime information first has to discover the location of this data. Content referencing services are 
located by accessing the resolution provider notification table (RNT). Metadata services are located by following 
linkage that may be present in a number of places, depending on whether the metadata sought relates to content, a 
service's schedule, or another type of entity. 

A key concept in TV-Anytime for discovering content referencing information is the resolution provider. On DVB 
transport streams a resolution provider is a separate entity described by a resolution provider notification table (RNT). 
The resolution provider entity is independent of networks, bouquets and DVB services. Therefore, a resolution provider 
may provide content resolving information for CRIDs that refer to content carried on one or more networks, bouquets or 
DVB services. Conversely, a network, bouquet or DVB service may deliver content described by more than one 
resolution provider. 

NOTE: A resolution provider may carry information on CRIDs published by one or more CRID authorities. For 
details on CRID authorities and resolution providers see TS 102 822-4 [6]. 
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This clause defines how information regarding resolving authorities' entities shall be represented and discovered on a 
DVB broadcast network and how content referencing services and metadata services shall be discovered. 

5.2 Resolution providers 
5.2.1 Discovering RARs 

On a DVB transport stream, Resolving Authority Records (RARs) are represented by RAR descriptors, which are 
carried in the resolution provider notification table (RNT) (see clauses 5.2.2, 5.3.5 and 5.3.6). This clause describes the 
process for discovering RARs relevant to a given combination of resolution provider and CRID authority. See figure 3 
for a graphical representation of an example implementation of this process. 

NOTE 1: The term "resolving authority" is a synonym for "resolution provider." Therefore a resolving authority 
record (RAR) refers to a particular resolution provider. 

RNT sub_tables shall be carried on a fixed PID, with each RNT sub_table being distinguished by its context_id, 
context_id_type and the transport stream the sub_table is carried on. The context_id may be a bouquet ID, original 
network id, or another type of identifier. The type of value carried by the context_id is identified by the value of 
context_id_type (see table 2). Each RNT sub_table can carry information on one or more resolution providers, each 
being distinguished by their resolution_provider_name. A receiver may be configured by means outside the scope of the 
present document to know the values of context_id, context_id_type and resolution_provider_name it should use. 

NOTE 2: The use of the context_id_type allows a RNT sub_table to be targeted at a particular population of 

receivers in the best way for a given circumstance. The best value of context_id_type to use may depend, 
for example, on whether or not a network uses bouquets, or the way network_ids are used. 

If a RNT sub_table does not list all CRI sets for all CRID authorities for all resolution providers for that combination of 
context_id and context_id_type, then it shall contain a RNT scan descriptor. If included, the RNT scan descriptor shall 
contain a complete list of transport streams where RNT sub_tables with the same context_id and context_id_type are 
available. A RNT scan descriptor may or may not contain an entry referencing the transport stream in which the current 
RNT is carried. It is possible that CRI sets are available from multiple resolution providers for a particular CRID 
authority. 
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flow of I flow of 
control I data 




Figure 3: Example procedure for acquiring CRI (informative) 

5.2.2 Resolution provider notification table 

The resolution provider notification table (RNT) carries information provided by resolution providers relating to GRID 
authorities (see TS 102 822-4 [6], clause 6), providing the locations of CRI and metadata for those GRID authorities. 

Each RNT sub_table provides information on a particular context (see clause 5.2.1). An RNT sub_table is distinguished 
by context_id, context_id_type and the transport stream the RNT is carried on. RNTs with the same context_id and 
context_id_type but carried on different transport streams shall not be considered the same sub_table. 

The RNT shall be segmented into sections using the syntax of table 1 . Sections forming part of the RNT shall be carried 
in TS packets with a PID value of 0x0016. 
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Table 1 : Resolution Provider Notification Section 



Name 


No. of bits 


Identifier 


resolution authority notification section () { 






table id 


8 


uimsbf 


section syntax indicator 


1 


bslbf 


reserved 


1 


bslbf 


reserved 


2 


bslbf 


section length 


12 


uimsbf 


context id 


16 


uimsbf 


reserved 


2 


bslbf 


version number 


5 


uimsbf 


current next indicator 


1 


bslbf 


section number 


8 


uimsbf 


last section number 


8 


uimsbf 


context id type 


8 


uimsbf 


reserved 


4 


bslbf 


common descriptors length 


12 


uimsbf 


for (i=0; i<Nl; i++) { 






descriptor ( ) 

} 

for (i<0; i<N2; i++) { 










reserved 


4 


bslbf 


resolution provider info length 


12 


uimsbf 


resolutionj>rovider name length 


8 


uimsbf 


for (j<0; j<resolution_provider name_length; j++) { 






resolution provider name byte 

} 

reserved 


8 


uimsbf 


4 


bslbf 


resolution provider descriptors length 


12 


uimsbf 


for (j=0; j<N3; j++) { 






descriptor ( ) 

} 

for (j=0; j<N4; j++) { 










GRID authority name length 


8 


uimsbf 


for (k<0; k<CRID authority name length; k++) { 






GRID authority name byte 

} 
reserved 


8 


uimsbf 


2 


bslbf 


GRID_authority policy 


2 


bslbf 


GRID authority descriptors length 


12 


uimsbf 


for (k=0; k<N5; k++) { 






GRID authority descriptor () 
} 
} 
} 
GRG 3 2 

} 






32 


rpchof 



tablejd: This field shall be set to 0x79 (see EN 300 468 [1]). 

section_syntax_indicator: This field shall be set to '1'. 

reserved: Fields marked as reserved shall have all bits set to '1'. 

sectionjength: This field specifies the number of bytes of the section, starting immediately following the 
sectionjength fields and including the CRC. The sectionjength shall not exceed 4 093 so that the entire section has a 
maximum length of 4 096. 

context_id: This field identifies a particular context to which this sub_table applies. 

version_number: This 5-bit field is the version number of the sub_table. The version_number shall be incremented by 
1 when a change in the information carried within the sub_table occurs. When it reaches value 31, it wraps around to 0. 

current next indicator: This 1-bit indicator shall be set to T'. 
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section_number: This 8-bit field gives the number of the section. The section_number of the first section in the 
sub_table shall be "0x00". The section_number shall be incremented by 1 with each additional section with the same 
table_id, context_id and context_id_type. 

last_section_number: This 8-bit field indicates the number of the last section (that is, the section with the highest 
section_number) of the sub_table of which this section is part. 

context_id_type: This field defines the type of the context to which this sub_table applies. It shall be encoded 
according to table 2. 

Table 2: context_id_type 



Value 


Semantics 


0x00 


context id is a value of bouquet id 


0x01 


context id is a value of original network id. 


0x02 


context id is a value of network id 


0x03 to 0x7F 


DVB reserved 


0x80 to OxFF 


User defined 



common_descriptors_length: The total length in bytes of the following descriptors. 

resolution_provider_info_length: This field specifies the number of bytes in this resolution provider entry, starting 
immediately after this field and including information on all CRID authorities within this entry. 

resolution_provider_name_length: The total length in bytes of the resolution provider name. 

resolution_provider_name_byte: This byte forms part of a sequence that is the resolution provider name for this entry. 
The resolution provider name is a registered internet domain name. See RFC 1591 [12] for DNS name registration. The 
resolution provider name is case insensitive and must be a fully qualified name according to the rules given by 
RFC 1591 [12].SeeTS 102 822-4 [6], clause 11.1. 

resolution_provider_descriptors_length: The total length in bytes of the following descriptors. 

CRID_authority_name_length: The total length in bytes of the CRID authority name. 

CRID_authority_name_byte: This byte forms part of a sequence that is the CRID authority name string. The encoding 
of this field follows the same rules as for the resolution provider name. See TS 102 822-4 [6], clause 11.1. 

CRID_authority_policy: This field indicates the policy on CRID re-use for this authority, it shall be encoded 
according to table 3. 

Table 3: CRID_authority_policy 



Value 



Semantics 



'00' 



CRIDs published by this CRID authority are permanent (i.e. they are not re-used ever). 



'01' 



CRIDs published by this CRID authority are transient (i.e. they may be re-used for different content over time). 
Each CRID published by this CRID authority may be either transient or permanent. 



'10' 



'11' 



Reserved. 



For CRID authorities with a CRID authority policy value of '10' the mechanism by which the transient or permanent 
status of a particular CRID is assigned is not defined by the present document. 

CRID_authority_descriptors_length: The total length in bytes of the following descriptors. 

CRC_32: This is a 32-bit field that contains the CRC value that gives a zero output of the registers in the decoder 
defined in EN 300 468 [1] after processing the entire private section. 



£75/ 



19 



ETSI TS 102 323 VI .5.1 (2012-01) 



5.3 Descriptors 

5.3.1 Parsing of descriptors 

When parsing any one of the descriptors defined by the present document, receivers shall always use the descriptor 
length field to determine the length of the descriptor. 

NOTE: In common with all DVB descriptors the receiver should always use the encoded descriptor length when 
parsing or skipping a descriptor. This is because DVB may in the future extend the syntax beyond that 
currently understood by the receiver. 

5.3.2 Descriptor identification and location 

Table 4 lists the descriptors defined or profiled in the present document, giving their intended placement and their 
values of descriptor_tag and descriptor_tag_extension where applicable. 

Table 4: Possible locations of descriptors 



Descriptor 


Tag 
value 


Tag 
ext 


Clause 


NIT 

1 


NIT 
2 


BAT 

1 


BAT 
2 


SDT 


PMT 
2 


EIT 
s 


EIT 
pf 


RNT 

1 


RNT 
2 


RNT 
3 


RCT 

1 


RCT 
2 


metadata pointer 
descriptor 


0x25 


- 


5.3.3 


* 




* 


* 










* 




* 






metadata descriptor 


0x26 


- 


5.3.4 












* 
















RAR over DVB stream 
descriptor 


0x40 


- 


5.3.5 






















* 






RAR over IP descriptor 


0x41 


- 


5.3.6 






















* 






RNT scan descriptor 


0x42 


- 


5.3.7 


















* 










content labelling descriptor 


0x24 


- 


5.3.8 












* 
















default authority descriptor 


0x73 


- 


6.3.3 


* 


* 


* 


* 


* 


















related content descriptor 


0x74 


- 


10.3 












* 
















TVA id descriptor 


0x75 


- 


11.2 
















* 












content identifier descriptor 


0x76 


- 


12.1 














* 


* 












image icon descriptor 


0x7F 


0x00 


10.4.3 
























* 


* 


NOTE 1 : NIT 1 : common (outer) descriptor loop of the NIT. 
NIT 2: transport stream descriptor loop of the NIT. 
BAT 1 : common descriptor loop of the BAT. 
BAT 2: transport stream descriptor loop of the BAT. 
PMT 2: elementary stream descriptor loop of the PMT. 
BIT s: the descriptor loop of the EIT schedule. 
EIT pf: the descriptor loop of the EIT present/following. 
RNT 1 : common descriptor loop of the RNT. 
RNT 2: resolution provider descriptor loop of the RNT. 
RNT 3: GRID authority descriptor loop of the RNT. 
RCT 1 : common descriptor loop of the RCT. 
RCT 2: descriptor loop in the link info structure of the RCT. 


NOTE 2: The descriptor tag values 0x40-0x42, inclusive, in the above table, override the definition of the meaning of 
those descriptor tags in EN 300 468 [1 ], when they are used in the RNT table only. 



5.3.3 Metadata pointer descriptor 



5.3.3.1 



Usage 



The metadata pointer descriptor defines linkage to a metadata service. The scope of that linkage is either global, 
transport stream, a DVB service or a CRID authority. The metadata service should carry information relevant to the 
scope of the linkage. For example, if a metadata service linkage is located in the descriptor loop of an SDT for a 
particular DVB service, it should carry information relating to that DVB service. A single metadata service may be 
referenced from a number of different locations and may therefore carry information relevant to a number of scopes. 
Table 5 defines the intended locations of the metadata pointer descriptor and gives example fragment types (see 
TS 102 822-3-2 [5], clause 4.3.1) relevant to that location. 
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Table 5: Permitted locations of the metadata pointer descriptor 



Scope 


Linkage location 


Example metadata fragment types 


Global 


BAT 1^' loop, NIT 1"" loop, common 
descriptor loop of the RNT, resolution 
provider descriptor loop of the RNT 


BroadcastEvent, Schedule, Servicelnformation, 
Programlnformation, Grouplnformation, Review, 
Segmentlnformation, SegmentGrouplnformation, 
PersonName, OrganizationName. 


Transport stream 


BAT 2™ loop, NIT 2™ loop 


BroadcastEvent, Schedule, Servicelnformation, 
Programlnformation, Grouplnformation, Review, 
Segmentlnformation, SegmentGrouplnformation, 
PersonName, OrganisationName. 


DVB Service 


Service loop of the SDT 


BroadcastEvent, Schedule, Servicelnformation. 


GRID authority 


GRID authority descriptor loop of the 
RNT 


Programlnformation, Grouplnformation, Review, 
Segmentlnformation, SegmentGrouplnformation, 
PersonName, OrganizationName. 



5.3.3.2 



Semantics 



This clause defines the use and additional semantics of fields of the metadata pointer descriptor. See 
ISO/IEC 13818-1 [9], clause 2.6.58 for the format and basic semantics of this descriptor. This descriptor shall be used 
with the constraints given below when associating an entity in a DVB network with a metadata service delivering 
relevant TV-Anytime metadata. 

metadata_applicatioii_format: This field shall have the same value as encoded in the metadata_application_format 
field of the metadata descriptor describing the target metadata service (see clause 5.3.4), that is the metadata descriptor 
with matching metadata_service_id carried in the PMT sub_table indicated by this descriptor. 

metadata_application_format_identifier: This field shall not be used. 

metadata_format: The value of this field shall be set according to table 6. If the metadata service is delivered in a 
DVB transport stream, the value of this field shall match the value of the metadata_format field in the metadata 
descriptor with a matching value of metadata_service_id in the PMT sub_table identified by this descriptor (see 
clause 5.3.4). 

Table 6: metadata format 



Value 


Semantics 


0x00 to GxSE 


Not used in the present document. 


0x3F 


Defined by metadata application format. 


0x40 to OxEF 


User defined. 


OxFO 


The encoding and encapsulation format as defined in 
clauses 9.3 and 9.4 of the present document. 


OxF1 to 0xF7 


DVB Reserved. 


0xF8 to OxFE 


User defined. 


OxFF 


Not used in the present document. 



metadata_format_identifier: This field shall not be used. 

metadata_service_id: This field shall be used to identify which metadata service this descriptor references. When that 
metadata service is delivered in a DVB transport stream, the target metadata service shall be described by a metadata 
descriptor with a matching value of metadata_service_id in the PMT sub_table identified by this descriptor (see 
clause 5.3.4). 

metadata_locator_record_flag: This field shall be set to '0' if this descriptor references a metadata service delivered in 
a DVB transport stream. Otherwise, this field shall be set to '1' (for example, if delivered over bi-directional IP 
according to TS 102 822-6-1 [18]). If the metadata_format field is set to OxFl then this field shall be set to '1'. 

metadata_locator_record_length, metadata_locator_record: An option that may be used to point to an arbitrary 
URL not within a DVB network. If it is used the metadata locator record shall contain a compliant URI 
(see RFC 3986 [2]) which shall be encoded as described in clause 6.2. If this field contains a HTTP URL as specified in 
RFC 1945 [19], then that URL shall reference a metadata service that conforms to TS 102 822-6-1 [18]. 
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MPEG_carriage_flags: A 2-bit field that shall be coded according to table 7. If the metadata_locator_record_flag is set 
to '1' then this field shall be set to 3. Otherwise, this field shall be set to either or 1. 

Table 7: MPEG_carriage_flags 



Value 


Semantics 





Carried in the "actual" DVB transport stream. 


1 


Carried in another DVB transport stream. 


2 


Not used in the present document. 


3 


None of the above - may be used if there is no relevant 
metadata carried on the DVB network. In this case the 
metadata locator record shall be present. 



Together the following three fields make up the normal triple that define a DVB service. 

program_number: This field shall be set to the service_id in which the referenced metadata service can be found. 

transport_stream_location: This field shall be set to the original_network_id. If not present the program number 
refers to the actual transport stream. 

transport_stream_id: This field shall be set to the transport_stream_id. If set to 0x0000 this field shall be ignored and 
the combination of transport_stream_location and program_number define the original_network_id and service_id that 
uniquely identify the service in which the reference metadata can be found. 

private_data_bytes: This field shall contain the metadata descriptors extension structure as defined in table 10. If the 
metadata service is delivered in a DVB transport stream, the DVB_carriage_format field of the metadata descriptors 
extension structure shall be set to the same value as encoded in the D VB_carriage_format field of the metadata 
descriptors extension structure in the metadata descriptor describing the target metadata service (see clause 5.3.4), that 
is the metadata descriptor with matching metadata_service_id carried in the PMT sub_table indicated by this descriptor. 



5.3.4 Metadata descriptor 



5.3.4.1 



Usage 



MPEG-2 part 1: Carriage of metadata over ISO/IEC 13818-1 [9] streams defines the metadata descriptor (see 
clause 2.6.60 of ISO/IEC 13818-1 [9] streams). This descriptor with the constraints given below shall be carried in PMT 
sub_tables in the descriptor loop of an elementary stream that carries the DSI of an MHP object carousel delivering one 
or more metadata services (see clause 9.2). It is used to describe the format and download parameters of the metadata 
service carried on that elementary stream. 



5.3.4.2 



Semantics 



This clause defines the use and additional semantics of fields of the metadata descriptor. See MPEG-2 part 1 [9], 
clause 2.6.60 for the format and basic semantics of this descriptor. 

metadata_application_format: This field shall have the value 0x0100. The use of this value signifies that the metadata 
service contains TVA metadata as profiled according to DVB (see clause 8). 

metadata_application_format_identifier: This field shall not be used. 

metadata_format: The value of this field shall be set according to table 6 in clause 5.3.3.2. 

metadata_format_identifier: This field shall not be used. 

metadata_service_id: This field indicates the metadata service to which this descriptor applies. This value shall be 
unique within the scope of the PMT sub_table in which this descriptor is carried. 

decoder_config_flags: This field indicates the location of the DVB-TV A-init message (see clause 9.4.2.1). 

If the DVB_carriage_format field is set to then this field shall have the value '000' if the DVB-TV A-init message is 
carried in a BIOP::FileMessage object referenced by the default file name, or it shall have the value 'Oil' if the 
DVB-TV A-init message is carried in a BIOP::FileMessage object referenced by the 
dec_config_identification_record_bytes. No other values of decoder_config_flags are permitted. 
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For other values of DVB_carriage_format the semantics of this field are undefined. 

DSM-CC_flag: This field shall be set to '1' if the metadata is carried in an ISO/IEC 13818-6 [13] data or object 
carousel. Otherwise it shall be set to '0'. 

service_identification_record_byte: This field is part of a sequence that conveys the metadata service location string. 

If the DVB_carriage_format field is set to then the following rules apply: 

• This string is the location of the metadata service within the object carousel associated with this descriptor. 
The location is described as a file path that references the directory within which the metadata service's 
containers can be found. 

• If the service_identification_record_byte sequence is a string with length greater than zero, then contents of 
this field define the service location string (mds_explicit_path). If this sequence is a zero-length string, then 
the default value of the metadata service location string shall be used (mds_default_path). The format of the 
metadata service location string is defined in table 8. 

Table 8: Metadata service location string 



metadata service location 


stri 


ng 


= mds explicit 


path 


1 mds default path 


mds explicit path 






= "/" path segments 




mds default_path 






= "/" metadata 


service id string 


metadata service id string 






= hex string 






hex string 






= 2*hex 






hex 






= digit 1 "A" 


"B" 


1 "C" 1 "D" 1 "E" 1 "F" 


digit 






= "0" 1 "1" 1 
"7" "8" 


'2" 1 
'9" 


"3" 1 "4" 1 "5" 1 "6" 1 



The format for path_segments is defined in RFC 3986 [2]. 

The format for metadata_service_id_string is the value of metadata_service_id carried in this descriptor encoded as a 
hex_string. 

Below are example metadata service location paths. The first two examples are explicitly encoded in the 
service_identification_record_byte field. The last example is a default metadata service location path, defined by a 
zero-length service_identification_record_byte sequence and where the metadata_service_id is set to 0x9A: 

"/metadata/service 1 " 

tt /tt 

79A" 

For other values of DVB_carriage_format the semantics of this field are undefined. 

dec_config_identification_record_byte: This field is part of a sequence that conveys the location of the decoder 
configuration. 

If the D VB_carriage_format field is set to then the following rules apply: 

The location is described as a file path that references the BIOP::FileMessage object within the metadata service 
referenced by this descriptor, which carries the DVB-TV A-init message (see clause 9.4.2.1). The format of this field is 
defined thus: 

• If the dec_config_identification_record_byte sequence is a string with length greater than zero, then contents 
of this field define the location of the DVB-TV A-init message (the dti_explicit_path). If this sequence is a 
zero-length string, then the default value of the DVB-TV A-init message location shall be used (the 
dti_default_path). The format of the DVB-TV A-init message location is defined in table 9. 

Table 9: DVB TVA init message location 



DVB_TVA_init_msg_location = dti_explicit_path | dti_def ault_path 

dti_explicit_path = "/" path_segments 

dti_def ault_path = "/" metadata_service_id_string 

metadata_service_id_string = metadata_service_location_string 
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The format for path_segments is defined in TS 102 812 [11], clause 14.1. 

The format for the metadata service location string is conveyed by the service_identification_record_bytes. See 
semantics for that field, above. 

For other values of DVB_carriage_format the semantics of this field are undefined. 

private_data_bytes: This field shall contain the metadata_descriptors_extension structure as defined in table 10. 
Otherwise, the contents of this field are not defined. 

Table 10: Metadata descriptors extension 



Name 


No. of bits 


Identifier 


metadata descriptors extension {) { 






DVB carriage format 


4 


uimsbf 


reserved 


2 


uimsbf 


metadata service identifier flag 


1 


bslbf 


fragment types_flag 


1 


bslbf 


if {fragment types flag == '0') { 






number of types 


8 


uimsbf 


for {i=0; i<number of types; i++) { 






fragment type 
} 


16 


uimsbf 


} 

if {metadata service identifier flag == "0') { 






metadata service identifier length 


8 


uimsbf 


for {i=0; i<metadata service identifier length; i++) { 






metadata service identifier byte 
} 


8 


uimsbf 


} 

for {i=0; i<N; i++) { 






user data byte 
} 
} 


8 


bslbf 



DVB_carriage_format: This field defines the precise delivery format used for this metadata service. It shall be 
encoded according to table 1 1 . 

Table 1 1 : DVB_carriage_format 



Value 


Semantics 





Delivery as defined in clause 9.2. 


1 


Delivered according to TS 102 034 [8], clause 5.4 


2 to 7 


DVB reserved 


8 to 14 


User defined 


15 


Not applicable 



reserved: All bits in this field shall be set to '1'. 

metadata_service_identifier_flag: This flag indicates the presence of a metadata service identifier. If the identifier is 
present this field shall be set to '0', otherwise it shall be set to T. 

fragment_types_flag: This flag indicates the presence of a list of fragment_types. If the list of fragment_types is 
present this field shall be set to '0', otherwise it shall be set to '1'. 

number_of_types: This field shall be set to the number of fragment_type fields that follow. 

fragment_type: This field identifies a type of metadata fragment found in the metadata service the descriptor carrying 
this metadata_descriptors_extension refers to. This field shall be encoded according to TS 102 822-3-2 [5], table 7. 

metadata_service_identifier_length: The total length in bytes of the metadata service identifier. 

metadata_service_identifier_byte: This byte forms part of a sequence that is the metadata service identifier string. See 
clause 9.6. 
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NOTE 1 : When locating metadata for a particular purpose, there may be more than one metadata service relevant to 
a particular entity. Using this optional feature to identify certain fragment types in each metadata service 
can reduce the need to search each metadata service in turn, speeding acquisition of metadata and 
reducing load on receiver resources. 

NOTE 2: The list of fragment types does not need to be exhaustive for the particular metadata service being 
referenced. 

5.3.5 RAR over DVB stream descriptor 

The RAR over DVB stream descriptor encapsulates a RAR for a CRID authority whose data can be found on a DVB 
stream. This descriptor is permitted in the CRID authority descriptor loop of a RNT section. The format for this 
descriptor is defined in table 12. 

Table 12: RAR over DVB Stream descriptor 



Syntax 


No. of bits 


Identifier 


RAR over DVB stream descriptor {) { 






descriptor_tag 


8 


uimsbf 


descriptor length 


8 


uimsbf 


first valid date 


40 


bslbf 


last valid date 


40 


bslbf 


weighting 


6 


uimsbf 


complete flag 


1 


bslbf 


scheduled flag 


1 


bslbf 


transport stream id 


16 


uimsbf 


original network id 


16 


uimsbf 


service id 


16 


uimsbf 


component tag 


8 


uimsbf 


if {scheduled_f lag ==1) { 






download start time 


40 


bslbf 


download_period duration 


8 


uimsbf 


download cycle time 
} 
} 


8 


uimsbf 



descriptor_tag: This field shall be set to 0x40. This overrides the definition of that descriptor tag value defined in 
EN 300 468 [1], when this descriptor tag is used inside an RNT. 

descriptorjength: This field shall be set to the number of bytes in this descriptor immediately following this field. 

first_valid_date: The first date when this CRID authority reference can be used. This field shall be encoded as MJD 
and UTC (see EN 300 468 [1], annex C). The 40-bit field is coded as 16 bits giving the 16 LSBs of MJD followed by 
24 bits coded as 6 digits in the 4-bit BCD. 

last_valid_date: The first date when this CRID authority reference cannot be used. This field shall be encoded as MJD 
and UTC (see EN 300 468 [1], annex C). The 40-bit field is coded as 16 bits giving the 16 LSBs of MJD followed by 
24 bits coded as 6 digits in the 4-bit BCD. 

NOTE: The reason for providing start and end dates for resolution is so that resolution providers can move their 
resolution URLs and be sure all PDRs have switched to the new URL once the last valid date of the old 
resolution record has passed. 

weighting: The weighting field is a hint to the PDR as to the order to try multiple records for a single CRID authority 
from the same resolution provider. The largest weighting number shall be assigned to the service that should be tried 
first. The weighting field is only used to provide ordering between resolution provider records for the same combination 
of resolution provider and CRID authority name and not for ordering one provider over another. 

complete_flag: This flag indicates if the referenced CRI data is complete. It shall be set to '1' if the referenced CRI data 
is complete, otherwise it shall be set to '0'. See clause 7.2.3 for details on the use of this field. 

scheduled_flag: This flag indicates if the referenced CRI data is delivered at a scheduled time, rather than being 
delivered continuously. It shall be set to '1' if the referenced CRI data is scheduled, or '0' if the referenced CRI data is 
delivered continuously. 



£75/ 



25 



ETSI TS 102 323 V1.5.1 (2012-01) 



transport_stream_id: This field shall be set to the transport_stream_id of the DVB service in which the referenced 
CRI is carried. If set to 0x0000 then this field shall be ignored and the DVB service shall be uniquely identified by a 
combination of original_network_id and service_id. 

original_network_id: This field shall be set to the original_network_id of the DVB service in which the referenced 
CRI is carried. 

service_id: This field shall be set to the service_id of the DVB service in which the referenced CRI is carried. 

component_tag: This field identifies the elementary stream on which the referenced CRI is carried. The 
stream_identifier_descriptor is mandatory for all components referenced by this descriptor (see EN 300 468 [1], 
clause 6.2.34). 

download_start_time: This field describes the date and time at which the CRI service will start to be available. This 
field shall be encoded as MJD and UTC (see EN 300 468 [1], annex C). The 40-bit field is coded as 16 bits giving the 
16 LSBs of MJD followed by 24 bits coded as 6 digits in the 4-bit BCD. 

download_period_duration: This field describes the length of time from the start time during which the CRI service 
will be available. This field shall be encoded as a count of 6 minute periods. 

download_cycle_time: This field shall be set to the minimum time required for one complete repetition of all data in 
the CRI service, measured in minutes. 

5.3.6 RAR over IP descriptor 

The RAR over IP descriptor encapsulates a RAR for a CRID authority whose data can be found via an IP network. This 
descriptor is permitted in the CRID authority descriptor loop of a RNT section. The syntax for this descriptor is defined 
by table 13. 

Table 13: RAR over IP descriptor 



Syntax 


No. of bits 


Identifier 


RAR over IP descriptor {) { 






descriptor tag 


8 


Uimsbf 


descriptor length 


8 


uimsbf 


first valid date 


40 


bslbf 


last valid date 


40 


bslbf 


weighting 


6 


uimsbf 


complete flag 


1 


bslbf 


reserved 


1 


bslbf 


url length 


8 


uimsbf 


for {i=0; i < url length; i++) { 


8 


uimsbf 


url char 
} 
} 


8 


uimsbf 



descriptor_tag: This field shall be set to 0x41. This overrides the definition of that descriptor tag value defined in 
EN 300 468 [I], when this descriptor tag is used inside an RNT. 

descriptorjength: This field shall be set to the number of bytes in this descriptor immediately following this field. 

first_valid_date: The first date when this CRID authority reference can be used. This field shall be encoded as MJD 
and UTC (see EN 300 468 [1], annex C). The 40-bit field is coded as 16 bits giving the 16 LSBs of MJD followed by 
24 bits coded as 6 digits in the 4-bit BCD. 

last_valid_date: The first date when this CRID authority reference cannot be used. This field shall be encoded as MJD 
and UTC (see EN 300 468 [1], annex C). The 40-bit field is coded as 16 bits giving the 16 LSBs of MJD followed by 
24 bits coded as 6 digits in the 4-bit BCD. 

NOTE: The reason for providing start and end dates for resolution is so that resolution providers can move their 
resolution URLs and be sure all PDRs have switched to the new URL once the last valid date of the old 
resolution record has passed. 



£75/ 



26 



ETSI TS 102 323 V1.5.1 (2012-01) 



weighting: The weighting field is a hint to the PDR as to the order to try muhiple records for a single CRID authority 
from the same resolution provider. The largest weighting number shall be assigned to the URL that should be tried first. 
The weighting field is only used to provide ordering between resolution provider records for the same combination of 
resolution provider and CRID authority name and not for ordering one provider over another. 

complete_flag: This flag indicates if the referenced CRI data is complete. It shall be set to '1' if the referenced CRI data 
is complete, otherwise it shall be set to '0'. See clause 7.2.3 for details on the use of this field. 

reserved: Reserved bits shall be set to '1'. 

urljength: The length of the URL. 

url_char: The URL describing the location where CRIDs belonging to this CRID authority can be resolved. This field 
shall be encoded according to clause 6.2. 

5.3.7 RNT scan descriptor 

The RNT scan descriptor carries references to transport streams that carrying RNTs. This descriptor is permitted in the 
common descriptor loop of an RNT section, see clause 5.2. 1 for details on the use of this descriptor. The format for the 
RNT scan descriptor is defined by table 14. 

Table 14: RNT scan descriptor 



Syntax 


No. of bits 


Identifier 


RNT scan descriptor () { 






descriptor tag 


8 


uimsbf 


descriptor length 


8 


uimsbf 


for (i=0; i<N; i++) { 






transport stream id 


16 


uimsbf 


original network id 


16 


uimsbf 


scan weighting 
} 

} 


8 


uimsbf 



descriptor_tag: This field shall be set to 0x42. This overrides the definition of that descriptor tag value defined in 
EN 300 468 [1], when this descriptor tag is used inside an RNT. 

descriptorjength: This field shall be set to the number of bytes in this descriptor immediately following this field. 

transport_stream_id: This field carries the value of transport stream id of the transport stream referenced by this entry. 

original_network_id: This field carries the value of original network id of the transport stream referenced by this 
entry. 

scan_weighting: This field defines the intended order of tuning to other transport streams to acquire RNTs. An entry 
with a larger weighting value should be inserted before entries with smaller weightings. 



5.3.8 Content labelling descriptor 



5.3.8.1 



Usage 



The usage of the content labelling descriptor is defined in TS 102 823 [21], clause 5.2.4. TS 102 823 [21] defines usage 
of this descriptor in referencing broadcast timeline information for an item of content identified by a CRID. In this 
usage, this descriptor shall be present both in Synchronized Auxiliary Data and in the PMT for the DVB service in 
which the content is delivered. 



5.3.8.2 



Use in PMT 



For each elementary stream being used for synchronized auxiliary data that conveys one or more content labelling 
descriptors relating to this metadata application, i.e. "TVA metadata as profiled according to DVB", the concise form of 
the content labelling descriptor, as defined in TS 102 823 [21], clause 5.2.3.4, shall be present in the corresponding 
ES_info structure. 
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5.3.8.3 Semantics in Synchronized auxiliary data 

The syntax and semantics of this descriptor when conveyed within synchronized auxihary data is defined in 
TS 102 823 [21], clause 5.4.3. The following additional restrictions shall apply when used in the context of 
TV-Anytime segmentation: 

metadata_application_format: This field shall have the value 0x0100. The use of this value signifies that the metadata 
application is "TVA metadata as profiled according to DVB" (see clause 8). 

content_reference_id_record_flag: This 1-bit flag shall be set to '1'. 

content_time_base_indicator: This 4-bit field shall be set to 8. 

content_reference_id_byte: This is an 8-bit field. The sequence of content_reference_id_bytes specifies the content 
reference id field, which for the value of metadata application format above shall be used to explicitly define a CRID to 
be used as a label for the current item of content. 

The CRID may be encoded using the abbreviated CRID rules (see clause 6.3.1). If the CRID authority part is omitted 
there shall be a default authority defined for a scope encompassing the DVB service that the synchronized auxiliary data 
relates to (see clause 6.3.2). When the CRID authority part of the CRID URL is not present the forward-slash character 
("/") immediately following the CRID authority part must be present. 



6 CRIDs and other URIs in DVB networks 

6.1 Introduction 

This clause defines how CRIDs and other URIs shall be encoded in the structures defined in the present document. It 
also defines a mechanism for defining a default authority and associated scoping rules for the purpose of improving the 
compaction of CRIDs. 

6.2 Encoding of URI strings and the use of non-Latin characters 

The URI format (see RFC 3986 [2]) consists of a sequence of a limited range of Latin characters plus a limited number 
of graphical characters (e.g. "@", "=", etc. but not including a space character). In order for non-Latin characters to be 
used in URIs, a standard mapping from those non-Latin characters is defined. 

All characters not within the range of characters allowed in a URI must be encoded into UTF8 and included in the URI 
as a sequence of escaped octets. An escaped octet is encoded as a character triplet, consisting of the percent character 
"%" followed by the two hexadecimal digits representing the octet code. 

The syntax of the CRID is URI compliant and is defined in TS 102 822-4 [6]. Its format is as follows: 

• crid://<CRIDauthority>/<data> 
An example being: 

• crid://company.com/foobar 

CRIDs are insensitive to the case of characters. 

Where lexicographical ordering is applied to CRIDs in the present document, it shall be applied after characters not in 
the allowed range are converted into sequences of escaped octets. 
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6.3 Default authority and abbreviated CRIDs 

6.3.1 Abbreviated GRID rules 

In certain situations described in the present document a GRID string may use the following abbreviated forms. These 
reduce the overhead of a GRID string by leaving out information that can be inferred from the location of the GRID 
entry. 

Firstly, the characters "crid://" may be omitted from the start of the string so that the string starts with the first character 
of the GRID authority. So the example GRID: 

• crid://company.com/foobar 
may be encoded as: 

• company.com/foobar 

Additionally, within the scope of the definition of a default authority (see clause 6.3.2), the GRID authority part of the 
string may also be omitted if the GRID'S authority matches the current value of default authority. In this case the string 
starts with the delimiter between GRID authority and data parts of the GRID (i.e. "/"). Therefore, the example GRID: 

• crid://company.com/foobar 
may be encoded as: 

• /foobar 

6.3.2 Scope of a default authority definition 

A default authority is defined by the presence of a default authority descriptor. The purpose of the default authority is to 
allow a GRID reference within the scope of such a definition to leave out the protocol and authority parts of a GRID 
URI, if the GRID authority part of that GRID reference is the same as the defined default authority. 

The scope of a particular value of default authority is defined by the location of the default authority descriptor. A value 
of default authority defined in a scope overrides any value of default authority already defined for a wider, enclosing 
scope. See table 15 for definitions of the permitted locations of the default authority descriptor and which scope 
override which others. 

Table 15: Permitted locations of default authority descriptor 



Default authority descriptor location 


Scope of definition 


Scopes this definition overrides 


First descriptor loop of NIT 


network 


none 


Transport stream descriptor loop of NIT 


transport stream 


bouquet or network 


First descriptor loop of BAT 


bouquet 


none 


Transport stream descriptor loop of BAT 


transport stream 


bouquet or network 


Service descriptor loop of SDT 


service 


transport stream, bouquet or network 



The effect of defining a default authority in a BAT that conflicts with a definition of equivalent scope in a NIT is not 
defined by the present document. 

EXAMPLE: If a default authority is defined at the scope of a network, this can be overridden for a single 
service on that transport stream by the inclusion of a default authority descriptor in the service 
loop of an SDT on that transport stream. 
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6.3.3 Default authority descriptor 

The default authority descriptor is permitted in either the first of second descriptor loop of a NIT or BAT, or the service 
descriptor loop of a SDT. The syntax of this descriptor is defined in table 16. 

Table 16: Default authority descriptor 



Syntax 


No. of bits 


Identifier 


default authority descriptor {) { 






descriptor tag 


8 


uimsbf 


descriptor length 


8 


uimsbf 


for {i=0; i < descriptor length; i++) { 






default authority byte 
} 
} 


8 


uimsbf 



descriptor_tag: This field shall be set to 0x73 (see EN 300 468 [1]). 

descriptorjength: This field shall be set to the number of bytes in this descriptor immediately following this field. 

default_authority_byte: This field forms part of a sequence that is the default authority for this scope. The encoding of 
this field shall follow the rules defined in clause 5.2.2 for resolution_provider_name_byte. See also TS 102 822-4 [6], 
clause 6. 



6.4 



Profiled use of DVB locators 



The present document makes use of the DVB locator as defined in TS 102 851 [31]. 
When referencing a DVB service the DVB locator shall be restricted like so: 

dvb://<original_network_id>.[<transport_stream_id>].<service_id> 
When referencing an item of content the DVB locator shall be restricted to any of the following: 
To reference an item of content via an event_id carried in EIT (see clause 11.1): 

dvb://<original_network_id>. [<transport_stream>] .<service_id>;<event_id> [~time_duration] 
To reference an item of content via a TVA_id carried in EIT (see clause 1 1 .2.2): 

dvb://<original_network_id>.[<transport_stream>].<service_id>;;<TVA_id> [~time_duration] 
To reference an item of content via a TVA_id carried in PES (see clause 1 1 .2.3): 

dvb://<original_network_id>.[<transport_stream>].<service_id>.<component_tag>;;<TVA_id> [~time_duration] 
To reference an item of content via both, an event_id and a TVA_id carried in EIT: 

dvb://<original_network_id>.[<transport_stream>].<service_id>;<event_id>;<TVA_id> [~time_duration] 

To reference an item of content via both, an event_id and a TVA_id carried in PES: 

dvb://<original_network_id>.[<transport_stream>].<service_id>.<component_tag>;<event_id>; 
<TVA_id>[~time_duration] 

To reference an item of content by its scheduled time for broadcast (see clause 11.1): 

dvb://<original_network_id>.[<transport_stream>].<service_id>~time_duration 

A metadata fragment may contain a DVB locator referencing a file in an object carousel (see for example the Logo 
element in clause 8.6). When this occurs and the file is delivered in the same object carousel as the metadata service 
delivering the metadata fragment, the following syntax may be used for the DVB locator: 

dvb:/path_segments 
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This path shall be interpreted as being an absolute path, which is one that is relative to the ServiceGateway for the 
object carousel carrying the metadata service. The format of this shall follow the restrictions defined in 
TS 102 812 [11], clause 14.1.4. 

If a metadata fragment references a file delivered in a different object carousel to the metadata service delivering that 
metadata fragment, the following syntax shall be used for the DVB locator: 

dvb://<original_network_id>.[<transport_stream_id>].<service_id>$<carousel_id>/path_segments 



Content resolution 



7.1 Introduction 

The purpose of content referencing is to allow acquisition of a specific item of content or a group of items of content. 
For example, if a consumer sees a promotion on TV saying, "there'll be a new series on "Foxes in the cold" around 
Christmas", he may want to instruct his Personal Digital Recorder (PDR) to record the whole series. However the actual 
time and channel of airing of the episodes might be unknown to the PDR. In fact, the broadcaster may not know yet, 
either. However, at the time when the viewer sees the promotion he will want to make sure that he does not miss the 
opportunity to acquire the content. 

The ability to refer to content (in this example a series of programs) independent of its time or location will provide this 
capability desired by the consumer. Whether that location is on a particular broadcast channel on some date and time, or 
on a file server connected to Internet, or wherever. 

In the current example of a series, the PDR system would be provided with a reference for that series. In due time, the 
information required to link this reference to the individual episodes would be supplied to the PDR. Subsequently, a 
specific location (channel, date and time) would be provided for each episode so that the PDR would then be able to 
acquire all of them. 

Figure 4 demonstrates the purpose of content referencing: to provide the ability to refer to content independent of its 
location; and to provide the ability to subsequently resolve such a reference into one or more locations where the 
content can be obtained. 

Location Resolution is not a once-only operation. Receivers may need to re-resolve CRIDs at intervals before and 
during recordings in response to changes in the content referencing information. 

CRID(s) 





Resolution \-^^ > Locator(s) 

GRID > 



Figure 4: The location resolution process 

The key concept in content referencing is the separation of the reference to a content item - the CRID - from the 
information needed to actually retrieve the content item - the locator. The separation provided by the CRID enables a 
one-to-many mapping between content references and the locations of the deliverables. From a system perspective, 
content referencing and resolution lies between search and selection and actually acquiring the content. From the 
content referencing perspective, search and selection yields a CRID, which is resolved into either a number of CRIDs or 
a number of locators (the number may be one). A full discussion of content referencing is beyond the scope of the 
present document; rather it is the intention here to show how content referencing fits into the overall system. In the 
examples below, the syntax of a CRID and the syntax of a locator are employed. The syntax of a CRID is: 

CRID://<CRIDauthority>/<data> 
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Where <CRIDauthority> takes the form: 

<DNS name> 

<DNS name> is a registered Internet domain name or a delegated sub-domain within such a domain. (See 

RFC 1591 [12] for DNS name registration.) The <DNS name> is case insensitive and must be a fully qualified name 

according to the rules defined by RFC 1591 [12]. 

The syntax of the locator is: 

<transport mechanism>:<transport system specifio 

The content referencing mechanism employs two key elements. The first is the resolution provider notification table 
that maps the CRID authority that issued the CRID to the Resolution Service Provider. The second is the actual Content 
Resolution Information (CRI), which maps a CRID to another CRID or to a location. The CRI may also contain 
information to link a locator to metadata describing that instance. See TS 102 822-4 [6] for a more detailed explanation 
of the concepts and tables involved. 

7.2 Resolving CRIDs in a DVB network 
7.2.1 DVB transport stream resolution handler 

TS 102 822-4 [6], clause 10.1.1 describes a conceptual modular resolution system. The modular resolution system has 
different resolution handler modules, each handling a different protocol over which location resolving can occur. This 
clause defines the functionality of a DVB transport stream resolution handler module for the purpose of defining CRID 
resolving on DVB transport streams (see figure 5). 

The use of other types of resolution handler is supported. For example, a PDR may additionally support CRID 
resolution over the internet via a return path connection. 



CRID 



Resolving 

Authority 

Record 



CRIDs or 
Locators 
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DVB transport 

stream resolution 

handler 



Local storage 
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Back-channel 
resolution handler 



DVB transport stream 

/ \ 
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Referencing 

Information (CRI) 




Figure 5: Modular location resolving system 

7.2.2 CRI data sets 

CRI data consists of the information required to resolve CRIDs into its result (i.e. CRIDs or locators). On DVB 
transport streams, CRI data for a particular CRID authority is organized into one or more sets of CRI data (or "CRI data 
sets"). A CRI data set is the CRI data for a CRID authority in a particular content resolution service or internet location. 
See figure 6 for an example of different CRI data sets. References to CRI data are carried in Resolution Authority 
Records (RARs) which, on a DVB transport stream, are embodied in RAR descriptors (see clauses 5.3.5 and 5.3.6). 
These descriptors are carried in the resolution provider notification table (see clause 5.2.2). 
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Each content resolution service shall only contain CRI provided by one resolution provider. A content resolution service 
may contain CRI regarding more than one GRID authority (i.e. more than one CRI data set). 




Figure 6: Sets of CRI data in different locations 

7.2.3 Complete and incomplete CRI data sets 

Sets of CRI data may be signalled as either being complete or incomplete. A complete set of CRI data contains 
information on all CRIDs provided by a particular resolution provider for a particular CRID authority. 

Where a complete set of CRI data is supplied by a resolution provider for a CRID authority, incomplete sets of CRI data 
can be used in addition, for example to provide resolution information for CRIDs relevant to the local transport stream. 
Because of this a receiver may optimize location resolving by accessing an incomplete CRI data set in the current 
transport stream before falling back to accessing a complete CRI data set on another transport stream. 

CRI data provided by a resolution provider for a CRID authority may alternatively be distributed between several 
incomplete sets of CRI data, with no complete set being available. In this case, a receiver resolving a CRID should 
access all CRI data sets available from a resolution provider for the relevant CRID authority before returning an error. 

If a receiver is configured to access CRI provided by more than one resolution provider it should check both for CRI 
relating to a particular CRID authority. 

NOTE: Failure to resolve a CRID may be due to resolving information not being available for that CRID, or it 
may be because of a network failure. Therefore, a receiver may wish to continue to attempt to resolve 
such a CRID over a period of time not determined by the present document. 

7.3 Delivery of content referencing information 
7.3.1 Container 



7.3.1.1 



Description 



The container is the means by which all CRI structures shall be carried in a transport stream. A container shall contain 
one or more CRI structures. Each container is distinguished by a unique identifier, which is the container_id. Containers 
are mapped on to a table of MPEG 2 TS private sections, the headers of which carry the container_id. The container 
carrying the cri_index structure, which is the first structure required by the receiver, shall have its container_id set 
to 0x0000. 
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7.3.1.2 



Classifications of CRI structures and containers 



There are two classifications of CRI structures, CRI index structures and CRI results structures. 

CRI Index Structures: cri_index, cri_prepend_index cri_leaf_index, data_repository. 

CRI Results Structures: resultsjist, result_data, data_repository, services. 

A container carrying index structures is termed an index container, whilst a container carrying results structures termed 
a results container. A container can carry either a mixture of classifications of structure, or just a single classification. 
Therefore, a container can be both an index container and a results container. Figure 7 shows an example configuration 
suitable for a large set of CRI data, with CRI index structures separated into different containers than CRI results 
structures. Figure 8 shows an example configuration suitable for a small set of CRI data, with CRI index structures 
carried in the same container as CRI results structures. 

NOTE: The types of structures used in each example differ slightly because a cri_leaf_index structure does not 
require a resultsjist structure if it uses the local_result_locator. 



Index Containers 



Results Container 



container_header 
container id = 
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container id = 1 




data_repository 




container_header 
container id = 2 



results list 



result data 



services 



data_repository ■«- 



Figure 7: Example container structure for a large CRI data set 
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Index & Results 
Container 





container_header 
containerjd = 






crijndex 










cri_prependjndex 












„ 


crijeafjndex 












- 


result_data 


< — 




^ 


services 




data_repository 

























Figure 8: Example container structure for a small CRI data set 



7.3.1.3 



Container format 



Entries within the container_header shall be ordered in ascending cri_structure_type and cri_structiire_id. This enables a 
device to efficiently locate a particular structure. The maximum size of a container shall be 65 536 bytes. The format of 
the container is defined by table 17. 

Table 17: Container 



Syntax 


No. of bits 


Identifier 


container { 






container header { 






num cri structures 


8 


uimsbf 


for(j=0; j<num cri structures; j++) { 






cri structure type 


8 


uimsbf 


cri structure id 


8 


uimsbf 


cri structure ptr 


24 


uimsbf 


cri structure length 
} 


24 


uimsbf 


} 

for (j=0; j<num cri structures; j++) { 






cri structure 
} 
} 







nuin_cri_structures: This field specifies the number of structures in this container. 
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cri_structure_type: This field identifies the type of structure this entry relates to, it shall be encoded according to 
table 18. 

Table 18: CRI structure type and structure id 



cri_structure_type 
value 


cri_structure_id 
value 


Description 


0x00 


not defined 


reserved 


0x01 


0x00 


results list 


0x02 


0x00 


data repository 


0x03 


not defined 


reserved 


0x04 


0x00 to OxFF 


cri index 


0x05 


0x00 to OxFF 


cri prepend index or cri leaf index 


0x06 to 0x07 


not defined 


reserved 


0x08 


0x00 


result data 


0x09 


0x00 


services 


OxOA to OxEF 


not defined 


DVB Reserved 


OxFO to OxFF 


not defined 


User Private 



cri_structure_id: An 8 bit field used to distinguish between multiple instances of the same structure in a single 
container. This field shall be encoded according to table 18. Where only one value of cri_structure_id is allowed for a 
particular value of cri_structure_type, this indicates that only one occurrence of that cri_structure_type is allowed in a 
container. 

cri_structure_ptr: A 24 bit field giving the offset in bytes from the start of this container to the first byte of the CRI 
structure. 

cri_structure_length: A 24 bit field which indicates the length in bytes of the CRI structure pointed to by 
cri_structure_ptr. 



7.3.1.4 



Container section 



For delivery, a container is carried in a container_sub_table split into a sequence of one or more blocks of container 
data. Each block is carried as a section, the numbering of each section corresponding to the position of the container 
data block in the sequence. The sections for a container form a single container_sub_table, distinguished by 
container_id. Before a container can be parsed, all sections forming a single container_sub_table must be acquired. The 
container is reconstructed by appending container data blocks together in the order defined by the section number and 
reversing compression if this has been applied. 

The container section is derived from the standard private_section syntax as defined in ISO/IEC 13818-1 [9]. A 
container is carried by one or more container sections. Every container section shall carry 4 084 bytes of container data, 
except the container_section with section_number equal to last_section_number, which shall carry however many bytes 
remain of the container sub_table. The syntax of the container section is defined by table 19. 

Table 19: Container section 



Syntax 


No. of bits 


Identifier 


container section () { 






table id 


8 


uimsbf 


section syntax indicator 


1 


bslbf 


private indicator 


1 


bslbf 


reserved 


2 


bslbf 


private section length 


12 


uimsbf 


container id 


16 


uimsbf 


reserved 


2 


bslbf 


version number 


5 


uimsbf 


current next indicator 


1 


bslbf 


section number 


8 


uimsbf 


last_section number 


8 


uimsbf 


container data ( ) 






CRC3 2 
} 


32 


uimsbf 
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tablejd: This field shall be set to 0x75 (see EN 300 468 [1]). 

section_syntax_indicator: This shall be set to '1' to indicate that the private section follows the generic section syntax. 

private_indicator: This flag shall be set to '1'. 

private_section_length: The number of remaining bytes in the private section immediately following the 
private_section_length field up to the end of the private_section. 

container_id: This shall contain the container_id of the container carried by the table this section is part of 

version_number: The version of the table. The version shall be incremented by 1 modulo 32 when there is a change in 
the information. 

current_next_indicator: This field shall be set to '1' to indicate that the section is currently valid. 

section_number: This 8-bit field specifies the number of the private section. This section_number will be incremented 
by 1 with each additional section in the table. 

last_section_number: This specifies the number of the last section making up this table. 

container_data(): A sequence of bytes making up a portion of a compression_wrapper. 

CRC32: This field contains the CRC value that gives a zero output of the registers in the decoder defined in 
EN 300 468 [1] after processing the entire private section. 



7.3.1.5 



Compression wrapper 



The compression_wrapper allows a container to be carried in a compressed or uncompressed format. The syntax of the 
compression_wrapper is defined by table 20. 

Table 20: Compression_wrapper 



Syntax 


No. of bits 


Identifier 


compression wrapper () { 








compression method 




8 


uimsbf 


if (compression method == 0x00) 


{ 






container ( ) 








} else if (compression method = 


= 0x01) { 






original size 




24 


uimsbf 


compression structure () 
} 




Nx8 





compression_method: This field shall be encoded according to table 21. 

Table 21 : Compression method 



Value 


Meaning 


0x00 


The container is not compressed. 


0x01 


The container is carried in a Zlib stream as defined in RFC 1950 [20]. 


0x02 to 0x7F 


DVB reserved 


0x80 to OxFF 


User private 



containerQ: See clause 7.3.1.3 for the definition of the container structure. 

original_size: This field indicates the size in bytes of the container prior to compression. 

compression_structure: This shall contain a container structure (see clause 7.3.1.3) encoded as a Zlib stream (as 
defined in RFC 1950 [20]). When present, the Zlib stream shall have its compression method nibble set to '1000', 
indicating use of the Deflate compression algorithm as specified in RFC 1951 [17]. 
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7.3.2 CRI results structures 



7.3.2.1 



Description 



CRI results structures shall be used to carry Content Referencing Information on DVB transport streams. Individual 
CRID results conveyed within these structures shall be identified and located using the CRI indexing structures. Every 
CRID result has a handle_value that is used by index CRI structures to refer to a result. The results_list maps those 
handles to the relevant CRID result data, which is carried in the result_data structure. 

Of the following structures a results container shall contain those that are mandatory and may contain those that are 
optional: 

• resultsjist (Mandatory if results in this container are referenced by a cri_sub_index in another container); 

• result_data (Mandatory); 

• services (Mandatory if DVB binary locators are used). 



7.3.2.2 



Results list 



The resultsjist CRI structure associates results data with a handle_value. Entries within the resultsjist structure shall 
be in order of ascending handle_value. 

There shall be one instance of the resultsjist CRI structure within a results container if any CRI results in that container 
are referred to from other containers. The syntax of the resultsjist structure is defined by table 22. 

Table 22: Results list 



Syntax 


No. of bits 


Identifier 


results list () { 

for(j=0; j <NumCRIDs ; j++) { 
handle value 
result ptr 
} 
} 


16 
16 


uimsbf 
uimsbf 



handle_value: This field uniquely identifies a CRID result within the current container, this is for the purpose of 
referencing the CRID result from a cri_leaf_index. The value assigned to a CRID result should be persistent for the life 
of that CRID result so long as it is transmitted in the same container. If a CRID result moves from one container to 
another, the handle_value must then be unique within the new container. All entries shall be ordered by ascending value 
of handle_value. 

result_ptr: The offset, in bytes, from the first byte of the result_data structure of the current container to the first byte 
of the relevant content referencing information. 



7.3.2.3 



Result data 



7.3.2.3.1 



Usage 



The result_data CRI structure carries the CRID results data. There shall be one instance of the result_data CRI structure 
within a results container. Where locators carry time information, those locators for the results data for a single CRID 
shall be listed in start time order, earliest first. 

DVB locators contained within CRI shall include start time and duration information. 

See annex H for a description of the meaning of different combinations of acquisition_flag, re_resolve_flag and 
result_type. 
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7.3.2.3.2 Syntax 

The syntax of the resuh_data structure is defined by table 23. 

Table 23: Result data 



Syntax 


No. of bits 


Identifier 


result_data { ) { 






year offset 


16 


uimsbf 


for{j=0; j<Table size; j += sizeof (Result) ) { 






Status 


2 


uimsbf 


acquisition flag 


1 


bslbf 


re resolve flag 


1 


bslbf 


result type 


2 


bslbf 


imi flag 


1 


bslbf 


Reserved 


1 


bslbf 


if {status== ' 00 ' ) { 






num_results 


8 


uimsbf 


for{r=0; r<num results; r++) { 






if {result type == '00') { 






CRID_prepend_ptr 


16 


uimsbf 


result CRID data ptr 

} 

else if {result type == '01') { 


16 


uimsbf 






dvb binary locator {) 

} 

else if {result type == '10') { 










locator format 


4 


uimsbf 


locator length 


12 


uimsbf 


if {locator_format == 0x00) { 






for(j=0; j< (locator length - 1); j++) { 






URI byte 

} 

0x00 

} 

else if {locator format == 0x01) { 


8 


uimsbf 


8 


uimsbf 






dvb binary locator () 

} 

else if {locator format == 0x02) { 










scheduled decomposed binary locator () 

} 

else if {locator_format == 0x03) { 










on-demand decomposed binary locator () 

} 

else if {locator format == 0x04) { 










extended on-demand decomposed binary locator () 

} 
else { 










for(j=0; j<locator length; j++) { 






locator byte 
} 
} 
} 
else { 


8 


uimsbf 






DVB reserved length 


16 


uimsbf 


for {i=0; i<DVB reserved length; i++) { 






DVB reserved byte 
} 


8 


uimsbf 


} 

if {result_type != '00' && imi_flag == '1') { 






imi prepend ptr 


16 


uimsbf 


result imi data ptr 
} 
} 
} 
if {status == '01' II {status == '00' && re_resolve_f lag == '1' ) { 


16 


uimsbf 






reserved 


7 


bslbf 


reresolve date 


9 


uimsbf 
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Syntax 


No. of bits 


Identifier 


reresolve time 
} 
} 
} 


16 


uimsbf 



year_offset: The year relative to which date values in this structure shall be calculated. This field shall be encoded as 
the binary value of the year, for example "2003" would be encoded as 0x07D3. 

status: A two bit field used to indicate the current status of the CRID result. This field shall be encoded according to 
table 24. 

Table 24: CRID resolution status 



status 


IVIeaning 


'00' 


Valid result, CRID or locators follow 


'01' 


CRID is not yet resolvable 


'10' to '11' 


DVB Reserved 



It is not possible to encode a result with status "discard CRID", as defined by TS 102 822-4 [6], clause 12.2. 

acquisition_flag: A flag to indicate what type of acquisition is required for this CRID. This field shall be encoded 
according to table 25. 

Table 25: Acquisition flag 



acquisition flag 


Meaning 


'0' 


Acquire all items this CRID resolves into 


'1' 


Acquire any one of the items this CRID resolves into 



re_resolve_flag: A flag to indicate whether resolution of the CRID is complete. This field shall be encoded according 
to table 26. 

Table 26: Re-resolve flag 



re_resolve_flag 


Meaning 


'0' 


Resolution is complete 


'1' 


Resolution is incomplete, more resolution information to follow 



result_type: Indicates whether this is a group or leaf CRID and how they are encoded. This field shall be encoded 
according to table 27. 

Table 27: Result type 



result_type 


Meaning 


'00' 


Result is a list of CRIDs, from one or more CRID authorities. 


'01' 


Result is a list of DVB binary encoded locators. 


'10' 


Result is a list of locators, in mixed format. See table 29. 


'11' 


DVB Reserved. 



NOTE 1: If a CRID resolves to other CRIDs, rather than locators, it is possible that the CRID relates to a single 
programmes rather than a collection of programmes. This may occur, for example, when the options for 
capturing that single programme are too complex to be described as a list of locators. Therefore, where 
metadata is available, a receiver should try to access Programlnformation for a CRID that resolves to 
other CRIDs, if accessing Grouplnformation does not succeed. See clause 8.3. 

imi_flag: A flag to indicate whether Instance Metadata Identifiers (IMIs) are provided. This shall not be set to T if 
result_type is equal to '00'. This field shall be encoded according to table 28. 
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Table 28: IMI flag 



imi_flag 


Meaning 


'0' 


There are no IMIs for this Result 


'1' 


IMIs are provided for this Result 



nuin_results: The number of resolution results for this entry. 

CRID_prepend_ptr: The offset in bytes within the string data repository, where the CRID prepend string can be 
found. The first seven letters ("crid://") shall be omitted from the CRID prepend string. 

result_CRID_data_ptr: The offset, in bytes, from the first bytes of the data repository within the current container, to 
the first byte of the result CRID data string. Concatenating the string "crid://" with the prepend string and the result 
CRID data string shall result in a valid CRID. 

crid://<CRID prepend stringxresult CRID data string> 

locator_format: The format of the locator bytes. This field shall be encoded according to table 29. 

Table 29: Locator format 



Locator Format 


Meaning 


0x00 


URI compliant string followed by a byte of value 0x00. 


0x01 


DVB binary locator (see clause 7.3.2.3.3) 


0x02 


Scheduled decomposed binary locator (see clause 7.3.2.3.4) 


0x03 


On-demand decomposed binary locator (see clause 7.3.2.3.5) 


0x04 


Extended On-demand decomposed binary locator (see clause 7.3.2.3.6) 


0x05 to OxOB 


Reserved 


OxOC to OxOF 


Private Use 



URI_byte: A sequence of bytes representing a URI compliant string. The string shall include a valid URI scheme at the 
start. 

locatorjength: The number of bytes in the following locator. 

locator_byte: One of a sequence of bytes that together form the locator. 

DVB_reserved_length: The number of DVB_reserved_bytes. 

DVB_reserved_byte: A sequence of bytes reserved for future use. 

imi_prepend_ptr: The offset, in bytes, from the first bytes of the data repository within the current container, to the 
first byte of the prepend string for the IMI. Where the name portion of the IMI is the same as the CRID authority name 
part of the CRID that is being resolved, this field may point at a zero length string, in which case the prepend string 
shall be considered to be the CRID authority name. The "imi:" prefix shall be omitted from the IMI prepend string. 

result_iini_data_ptr: The offset, in bytes, from the first bytes of the data repository within the current container, to the 
first byte of the string which is the remaining part of the IMI. The act of concatenating the prepend string with the string 
pointed to by the result_imi_data_ptr results in a valid IMI. 

If the imi_flag is set to '1' but a result does not have an IMI, this condition shall be signalled by the result_imi_data_ptr 
for that result pointing to a zero-length string. This may occur in the case where some but not all of the results have 
been assigned IMIs. 

reresolve_date: The first date on which the receiver should try to re-resolve this CRID. This field uses Universal 
Co-ordinated Time (UTC) as the time reference. It shall be encoded as the number of days from the beginning of the 
year indicated by the year_offset field, the value zero indicating the T' of January of that year. 

NOTE 2: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

reresolve_time: The time, on the date given by reresolve_date, after which the receiver should try to re-resolve this 
CRID, using UTC as the time reference. This field shall be encoded as the number of 2-second periods since midnight. 
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7.3.2.3.3 DVB binary locator 

The syntax of the DVB binary locator sub-structure is defined by table 30. 

Table 30: DVB_binary_locator 



Syntax 


No. of bits 


Identifier 


dvb binary locator ( ) { 








identifier type 




2 


bslbf 


scheduled time reliability 




1 


bslbf 


inline service 




1 


bslbf 


reserved 




1 


bslbf 


start date 




9 


uimsbf 


if (inline service == '0') 


{ 






DVB service triplet ID 




10 


uimsbf 


} else { 








reserved 




2 


bslbf 


transport stream id 




16 


uimsbf 


original network id 




16 


uimsbf 


service id 

} 

start time 




16 


uimsbf 




16 


uimsbf 


duration 




16 


uimsbf 


if (identifier type == '01 


) { 






event id 

} 

if (identifier type == '10 




16 


uimsbf 


) { 






TVA id 

} 

if (identifier type == '11 




16 


uimsbf 


) { 






TVA_id 




16 


uimsbf 


component tag 

} 

if (identifier type == '00 




8 


uimsbf 


&& scheduled time reliability == '1')) { 






early start_window 




3 


uimsbf 


late end window 
} 
} 




5 


uimsbf 



identifier_type: This field indicates the type of event identifier used in this DVB binary locator. This field shall be 
encoded according to table 3 1 . 

Table 31 : Identifier type 



value 


Meaning 


'00' 


No event identifier field is present. 


'01' 


event identifier is an event id. 


'10' 


event identifier is a TVA id carried in EIT. 


'11' 


event identifier is a TVA id carried in PES. 



See clause 11.1 for details on the semantics of this field. 

scheduled_time_reliability: This field only has meaning when the value of identifier_type is '00', i.e. when no event 
identifier is provided and the receiver will need to use the scheduled time to control recording. When set, the 
early_start_window and late_end_window information shall be provided, which the receiver may use to improve the 
reliability of capture of the item of content (see clause 11.1). If the value of identifier_type is not '00' then this field shall 
be set to '0'. 

inline_service: This flag indicates how the original network ID, transport stream ID and service ID for the DVB service 
that this locator refers to may be found. If set to '1' this flag indicates that these values are carried in-line in this 
structure. If set to '0' these values are found in the services structure in the current container and are referenced by the 
DVB_service_triplet_ID. 

reserved: Reserved bits shall be set to '1'. 
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start_date: The date on which the content pointed to by this locator is scheduled to start. This field uses Universal 
Co-ordinated Time (UTC) as the time reference. It shall be encoded as the number of days from the beginning of the 
year indicated by the year_offset field in the enclosing structure. The value zero indicates the T' of January of that year. 

NOTE: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

DVB_service_triplet_ID: A zero-based index into the services structure present in the current container. The entry at 
this index shall contain the details of the DVB service (original network ID, transport stream ID and service ID) that 
this locator refers to. See clause 7.3.2.4 for the definition of the services structure. 

transport_streain_id: The transport stream ID for the transport stream that carries the DVB service that this locator 
refers to. If set to 0x0000 then this field shall be ignored and the DVB service shall be uniquely identified by a 
combination of original_network_id and service_id. 

original_network_id: The original network ID for the transport stream that carries the DVB service that this locator 
refers to. 

service_id: The DVB service ID for the DVB service that this locator refers to. 

start_time: The time at which the content pointed to by this locator is scheduled to start, using UTC as the time 
reference. This is encoded as the number of 2-second periods since midnight. 

duration: The duration of the event encoded as a count of 2-second periods. 

event_id: The value of event_id that may be used to detect the transmission of the content pointed to by this locator. 
See clause 11.1. 

TVA_id: The value of TVA_id that may be used to detect the transmission of the content pointed to by this locator. See 
clause 11.1. 

component_tag: This field identifies a packetized elementary stream (PES) within the DVB service that this locator 
refers to. The stream_identifier_descriptor is mandatory for all components referenced in this way (see EN 300 468 [1], 
clause 6.2.34). See clause 11.1. 

early_start_window: This field indicates a duration by which the start of transmission for the content pointed to by this 
locator may occur ahead of the scheduled start_time. This field shall be encoded as a count of 1 minute periods, giving a 
range of to 7 minutes. 

late_end_window: This field indicates a duration by which the end of transmission for the content pointed to by this 
locator may occur after the end time (which is calculated by adding the start start_time to the duration). This field shall 
be encoded as a count of 2 minute periods, giving a range of to 62 minutes. 
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7.3.2.3.4 



Scheduled decomposed binary locator 



The scheduled decomposed binary locator is used to signal the availability and location of scheduled content. The 
syntax of the scheduled decomposed binary locator is defined by table 32. 

Table 32: Scheduled_decomposed_binary_locator 



Syntax 


No. of bits 


Identifier 


scheduled decomposed binary locator () { 






scheduled time_reliability 


1 


bslbf 


reserved 


6 


bslbf 


start date 


9 


uimsbf 


start time 


16 


uimsbf 


duration 


16 


uimsbf 


if (scheduled time reliability == '1') { 






early start window 


3 


uimsbf 


late end window 

} 
reserved 


5 


uimsbf 


4 


bslbf 


URI_length 


12 


uimsbf 


for (i=0; i<URI_length; i++) { 






URI byte 
} 
} 


8 


uimsbf 



scheduled_time_reliability: When set, the early_start_window and late_end_window information shall be provided, 
which the receiver may use to improve the reliability of capture of the item of content (see clause 11.1). 

start_date: The date on which the content pointed to by this locator is scheduled to start. This field uses Universal 
Co-ordinated Time (UTC) as the time reference. It shall be encoded as the number of days from the beginning of the 
year indicated by the year_offset field in the enclosing structure. The value zero indicates the T' of January of that year. 

NOTE: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

start_time: The time at which the content pointed to by this locator is scheduled to start, using UTC as the time 
reference. This is encoded as the number of 2-second periods since midnight. 

duration: The duration of the event encoded as a count of 2-second periods. 

early_start_window: This field indicates a duration by which the start of transmission for the content pointed to by this 
locator may occur ahead of the scheduled start_time. This field shall be encoded as a count of 1 minute periods, giving a 
range of minute to 7 minutes. 

late_end_window: This field indicates a duration by which the end of transmission for the content pointed to by this 
locator may occur after the end time (which is calculated by adding the start start_time to the duration). This field shall 
be encoded as a count of 2 minute periods, giving a range of minute to 62 minutes. 

URIJength: The number of URI_bytes present in the following field. 

URI_byte: A sequence of bytes representing a URI compliant string. The string shall include a valid URI scheme at the 
start. 
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7.3.2.3.5 



On-demand decomposed binary locator 



The on-demand decomposed binary locator is used to signal the availability and location of on-demand content. The 
syntax of the on-demand decomposed binary locator is defined by table 33. 

Table 33: On-demand_decomposed_binary_locator 



Syntax 


No. of bits 


Identifier 


on-demand decomposed binary locator () { 






reserved 


6 


bslbf 


availability start date 


9 


uimsbf 


availability end date 


9 


uimsbf 


availability start time 


16 


uimsbf 


availability end time 


16 


uimsbf 


reserved 


4 


bslbf 


URI_length 


12 


uimsbf 


for (i=0; i<URI_length; i++) { 






URI byte 
} 
} 


8 


uimsbf 



availability_start_date: The first date on which the on-demand content pointed to by this locator becomes available. 
This field uses Universal Co-ordinated Time (UTC) as the time reference. It shall be encoded as the number of days 
from the beginning of the year indicated by the year_offset field in the enclosing structure. The value zero indicates the 
1 '■' of January of that year. 

NOTE: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

availability_end_date: The first date on which the content pointed to by this locator is no longer available. This field 
uses Universal Co-ordinated Time (UTC) as the time reference. It shall be encoded as the number of days from the 
beginning of the year indicated by the year_offset field in the enclosing structure. The value zero indicates the 1^' of 
January of that year. 

NOTE: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

availability_start_time: The time at which the on-demand content pointed to by this locator becomes available. This 
field uses UTC as the time reference. This is encoded as the number of 2-second periods since midnight. 

availability_end_time: The first time at which the on-demand content pointed to by this locator is no longer available. 
This field uses UTC as the time reference. This is encoded as the number of 2-second periods since midnight. 

NOTE: The duration of the on-demand content is signalled elsewhere in the TV-Anytime metadata and therefore 
does not need to be encoded in the locator. 

URIJength: The number of URI_bytes present in the following field. 

URI_byte: A sequence of bytes representing a URI compliant string. The string shall include a valid URI scheme at the 
start. 



7.3.2.3.6 



Extended On-demand decomposed binary locator 



The extended on-demand decomposed binary locator extends the on-demand decomposed binary locator defined in 
clause 7.3.2.3.5 with additional parameters to support download delivery of on-demand content as for example defined 
in TS 102 034 [8], clause 10 in addition to real-time streaming delivery The syntax of the extended on-demand 
decomposed binary locator is defined by table 34. 
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Table 34: Extended On-demand_decomposed_binary_locator 



Syntax 


No. of bits 


Identifier 


extended on-demand decomposed binary locator () { 






availability start date 


9 


uimsbf 


availability end date 


9 


uimsbf 


availability_start_time 


16 


uimsbf 


availability end time 


IG 


uimsbf 


delivery_mode 


1 


bslbf 


content_version 


8 


uimsbf 


Earlyjilayout 


1 


bslbf 


expiry time 


IS 


uimsbf 


expiry date 


9 


uimsbf 


URI_length 


12 


uimsbf 


for (i=0; i<URI length; i++) { 






URI byte 
} 
} 


8 


uimsbf 



delivery _mode: The delivery mode for the content. The supported modes are: 

delivery_mode="0": Streaming mode; streaming delivery of on-demand content 

delivery_mode="l": Download mode; download delivery of on-demand content 

If the delivery_mode is 0, i.e. streaming mode, then the semantics for the fields shall be identical to the ones specified in 
clause 7.3.2.3.5. The content_version, early_playout, expiry_date and expiry_time fields shall be set to and shall 
be ignored by the receiver. 

If the delivery_mode is 1, i.e. download mode, then the following semantics apply: 

availability_start_date: The first date on which the on-demand content pointed to by this locator becomes available for 
download delivery. The syntax as defined in clause 7.3.2.3.5 applies. 

availability_end_date: The first date on which the content pointed to by this locator is no longer available for 
download delivery. The syntax as defined in clause 7.3.2.3.5 applies. 

availability_start_time: The time at which the on-demand content pointed to by this locator becomes available for 
download delivery. The syntax as defined in clause 7.3.2.3.5 applies. 

availability_end_time: The first time at which the on-demand content pointed to by this locator is no longer available 
for download delivery. The syntax as defined in clause 7.3.2.3.5 applies. 

content_version: The version of the downloadable content. The version number counts from to 255 with an overflow 
from 255 to 0. 

early _playout: This flag indicates if the content play out can start while the download is still ongoing. 

early_playout = "0": play out SHALL NOT start before the content items is completely downloaded 

early_playout = "1": play out MAY start before the content item is completely downloaded. 

expiry _date: The date on which the download on-demand content pointed to by this locator expires and can be deleted 
from the local storage to which it was downloaded. This field uses Universal Co-ordinated Time (UTC) as the time 
reference. It shall be encoded as the number of days from the beginning of the year indicated by the year_offset field in 
the enclosing structure. The value zero indicates the P^ of January of that year. 

NOTE: The size of this field allows the encoded date to extend into the year following that encoded in the 
year_offset field. 

expiry_time: The time at which the download on-demand content pointed to by this locator expires and can be deleted 
from the local storage to which it was downloaded . This field uses UTC as the time reference. This is encoded as the 
number of 2-second periods since midnight. 
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URIJength: As defined in clause 7.3.2.3.5. 



URI_byte: As defined in clause 7.3.2.3.5. 



7.3.2.4 



Services 



The services CRI structure is used to provide an efficient means of identifying a DVB service by index. Items in this 
structure are referenced by the DVB_service_triplet_ID field of the results CRI structure (see clause 7.3.2.3). The index 
of the first entry is zero. There shall be at most one instance of this CRI structure within a container. The syntax of the 
services structure is defined by table 35. 

Table 35: Services structure 



Syntax 


No. of bits 


Identifier 


Services { 






for(j=0; j<NumServices ; j+ + ) { 






transport stream id 


16 


uimsbf 


original_network id 


16 


uimsbf 


service id 
} 
} 


16 


uimsbf 



transport_stream_id: The transport stream ID for the transport stream that carries the DVB service. If set to 0x0000 
then this field shall be ignored and the DVB service shall be uniquely identified by a combination of 
original_network_id and service_id. 

original_network_id: The original network ID for the transport stream that carries the DVB service. 

service id: The DVB service ID for the DVB service. 



7.3.2.5 



Data repository 



The data repository is used by both CRI index structures and CRI results structures for holding variable length strings. It 
can be present in an index container or in a results container. All references to a data repository refer to the data 
repository carried in the same container. The string_encoding field defines the encoding used for the strings contained 
within. There shall be at most one data repository in a container. The structure_id field in the container_header entry 
referring to a data_repository shall be set to 0x00. The syntax of the data repository is defined by table 36. 

Table 36: Data repository structure 



Syntax 


No. of bits 


Identifier 


data repository { 






string encoding 


8 


uimsbf 


for (i=0; i<item count; i++) { 






if (string_encoding < 0x03) { 






for (j=0; j<stringlength; j++) { 






string character 

} 

if (string encoding == 0x00) { 


8 


uimsbf 






0x00 


8 


uimsbf 


} else if (string encoding == 0x01) { 






0x00 


8 


uimbsf 


} else if (string encoding == 0x02) { 






0x0000 

} 

else { /* string encoding ^ 0x03*/ 










for (j=0; j<stringlength; j++) { 






private byte 
} 
} 
} 
} 


8 


uimsbf 
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string_encoding: An 8 bit field used to define the character encoding system. This field shall be encoded according to 
table 37. 

Table 37: String encoding 



Value 


Description 


Termination Value 


0x00 


8bitASCII(ISO/IEC646[24]) 


0x00 


0x01 


UTF-8 


0x00 


0x02 


UTF-16 


0x0000 


0x03 to OxEO 


reserved 


undefined 


OxE1 to OxFF 


User Private 


undefined 



7.3.3 CRI Index Structures 



7.3.3.1 



Description 



The CRI indexing format consists of a three level indexing system (see figure 9). The first level is described by a 
cri_index structure and the second by cri_prepend_index structures and the third by cri_leaf_index structures. 

The first level of indexing, consisting of a single cri_index structure, lists ranges of CRID values, referencing one 
cri_prepend_index structure for each range. 

The second level, consisting of cri_prepend_index structures, groups CRIDs together that have the same initial string, 
termed a prepend string. Each entry in the cri_prepend_index contains a prepend string and references the entries in the 
third indexing layer that represent CRIDs that start with that prepend string. 

The third level, consisting of cri_leaf_index structures, lists references to results and describes the variable string (the 
last part of the CRID). Every cri_prepend_index references one subordinate cri_leaf_index structure. The entries in a 
cri_prepend_index structure point to the relevant entries in the cri_leaf_index structure. 

The full CRID string is fully recoverable by concatenating the appropriate prepend string from the second level with the 
variable string of the third level. 

When assigning prepend strings the CRID string is treated as a simple sequence of characters that can be split at any 
point. The point at which the CRID string is split will depend on the amount of commonality in the first characters of 
the CRID strings encoded. 



crijndex 
(string range) 



crijDrependJndex 



cri leaf index 



from CRID://bbc.co.ul</a 
to CRID://bbc.co.ul</e 



fhom CRID://bbc.co.ul</f to^ fuom CRID://bbc.co.ul</t to 
(^ CRID://bbc.co.ul</s J[^ CRID://bbc.co.ul</z 



CRID://bbc.co.ul</films/ 
range_end_offset=2 



CRID://bbc.co.ul</soaps/ 
range_end_offset=4 



X 



I CRID://bbc.co.ul</sport/ 
I range_end_offset=6 



CD 



o 







Figure 9: Example illustrating the use of string ranges, prepend strings and variable strings 
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7.3.3.2 



Cri index 



The cri_index structure is the entry point for CRI carriage, it is the first structure that is located and decoded. It provides 
a list of all cri_prepend_index structures, describing the ranges of CRID values that those structures relate to. 

When the overlapping_subindices flag is set to T the receiver should attempt to de-reference CRID results for a 
particular CRID by retrieving and parsing matching cri_prepend_index structures in the order that they are found in the 
cri_index structures. 

Having overlapping ranges enables prioritization of particularly important CRIDs within the indexing structure. These 
CRIDs could be, for example, referencing programmes that are currently being broadcast or that will be broadcast very 
soon. Prioritization by grouping of results data is independent of prioritization (if any) within the indexing structures. 

When cri_prepend_index ranges are not flagged as overlapping (overlapping_subindices set to '0'), the 
cri_prepend_index entries within the cri_index shall be in ascending lexicographical order. Lexicographical ordering 
shall be applied to the encoded CRID string that is after converting characters outside of the standard Latin set into 
sequences of escaped octets, as defined in clause 6.2. 

There shall only be one cri_index CRI structure within the CRI data delivered on a single PID. The syntax of the 
cri_index structure is defined by table 38. 

Table 38: Cri index structure 



Syntax 


No. of bits 


Identifier 


cri index ( ) { 






overlapping subindices 


1 


bslbf 


reserved other use 


1 


bslbf 


reserved 


6 


bslbf 


result locator format 


8 


uimsbf 


for (i=0; i<prepend index count; i++) { 






if (overlapping subindices == 1) { 






low key value CRID 

} 

high key value CRID 


16 


uimsbf 


16 


uimsbf 


prepend index container 


16 


uimsbf 


prepend index identifier 
} 
} 


8 


uimsbf 



overlapping_subindices: When set to '1' indicates that one or more of the cri_prepend_index structures which form this 
index have ranges of values which overlap. Where cri_prepend_indices overlap entries in the cri_index structure are in 
descending order of search priority. When set to '0' indicates that the sub indices do not overlap, in which case the 
declared cri_prepend_index structures shall be ordered in ascending lexicographical order (see clause 6.2). 

reserved_other_use: This field shall be set to '0'. 

reserved: All bits marked as being reserved shall be set to '1'. 

result_locator_format: Identifies the format of the result locator structure within cri_leaf_index CRI structures 
referenced from this structure. This field shall be encoded according to table 39. 

Table 39: result locator format 



Value 


Meaning 


0x00 


local result locator 


0x01 


remote result locator 


0x02 to OxFF 


DVB reserved 



See clause 7.3.3.5 for definitions of the local_result_locator and remote_result_locator. 

low_key_value_CRID: This 16 bit field is the offset, in bytes, from the first byte of the data repository to the first byte 
of an abbreviated CRID string omitting the characters "crid://". This CRID string must have a lexicographical value 
equal to or less than any CRID string referred to by the referenced cri_prepend_index structure (see clause 6.2). 
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If the overlapping_subindices field is set to '0' then this field shall not be used. In this case, every CRID string referred 
to by the referenced cri_sub_index structure must have a lexicographical value greater than the high_key_value_CRID 
of the previous entry in this structure. 

high_key_value_CRID: This 16 bit field is the offset, in bytes, from the first byte of the data repository to the first byte 
of an abbreviated CRID string omitting the characters "crid://". This CRID string must have a lexicographical value 
equal to or higher than any CRID string referred to by the referenced cri_prepend_index structure (see clause 6.2). 

NOTE: When defining the range of values which a particular sub index is to cover, sufficient space can be left in 
containers to permit adding further CRID results without necessitating reallocation of the ranges of the 
sub index structures. 

prepend_index_container: This field is the container ID of the container carrying the cri_prepend_index structure. 

prepend_index_identifier: This 8 bit field shall be equal to the value of the cri_structure_id field of the target 
cri_prepend_index structure. 



7.3.3.3 



Cri_prepend_index 



The cri_prepend_index CRI structure comprises the second level of indexing. Each cri_prepend_index structure 
provides references (via a cri_leaf_index structure) to CRID results that are within the lexicographical range of values 
specified by the cri_index structure. 

For every cri_prepend_index structure there shall be a cri_leaf_index structure in the same container. These structures 
have the same cri_structure_type but are differentiated by their cri_structure_id values. All references to a 
cri_prepend_index or cri_leaf_index contain the cri_structure_id of the target structure, preventing confusion. 
Cri_prepend_index and cri_leaf_index CRI structures are also differentiable by the value of the leaf_flag field, which is 
present in both structures. 

All entries within the sub index shall be ordered in ascending lexicographical order (see clause 6.2). When trying to 
select the appropriate prepend string used for a CRID being resolved, the receiver shall select the longest matching 
prepend string. A matching prepend string is defined as one where all characters in the prepend string match the 
corresponding characters in the CRID. 

All entries that share the same prepend string shall be grouped together in the subordinate cri_leaf_index structure. 
These groups shall be in the same order as defined in the cri_prepend_index structure. For a given prepend string the 
correct range of cri_leaf_index entries is defined as being from one after the range_end_offset for the previous prepend 
string to the range_end_offset for the current prepend string. The start of the range for the first prepend string listed in a 
cri_prepend_index is the first entry in the subordinate cri_leaf_index. 

The syntax of the cri_prepend_index structure is defined by table 40. 

Table 40: Cri_prepend_index structure 



Syntax 


No. of bits 


Identifier 


cri prepend index ( ) { 






leaf flag 


1 


bslbf 


reserved 


7 


uimsbf 


sub index ref 


8 


uimsbf 


for (j=0; j<reference count; j++) { 






prepend_CRID_data 


16 


uimsbf 


range end offset 
} 
} 


16 


uimsbf 



leaf_flag: This shall be set to '0' indicating that this structure is a cri_prepend_index. 

reserved: All fields marked as being reserved shall have all bits set to '1'. 

sub_index_ref: This 8 bit field identifies the cri_structure_id of the cri_leaf_index that is the final level. The target 
cri_leaf_index shall be in the same container as this cri_prepend_index structure. 

prepend_CRID_data: This 16 bit field gives the offset, in bytes, from the first byte of the data repository to the first 
byte of the prepend string. 
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range_end_offset: This 16 bit field gives the zero-based index of the last entry within the relevant cri_leaf_index 
structure that shares the current prepend string. 



7.3.3.4 



Cri leaf index 



The cri_leaf_index CRI structure comprises the third level of indexing. Each entry in a cri_prepend_index structure 
provides the variable string part of a CRID and a reference to the results for that CRID. 

All entries within this structure shall be ordered in ascending lexicographical order. The syntax of the cri_leaf_index 
structure is defined by table 41. 

Table 41 : Cri leaf index structure 



Syntax 


No. of bits 


Identifier 


cri leaf_index() { 
leaf flag 
reserved 

for (j=0; j<reference count; j++) { 
variable_CRID_data 
result locator 
} 
} 


1 
7 

16 
variable 


bslbf 
uimsbf 

uimsbf 



leaf_flag: This 1 bit field shall be set to '1', indicating that this is a cri_leaf_index structure. 

reserved: All fields marked as being reserved shall have all bits set to '1'. 

variable_CRID_data: This 16 bit field gives the offset, in bytes, from the first byte of the data repository to the first 
byte of the variable CRID string for this entry. Concatenating the string "crid://" with the relevant prepend CRID data 
and the variable CRID data shall result in a valid CRID. 

resultjocator: This sub-structure references the results for this CRID. The format of this locator is dependent on the 
result_locator_format defined for this index within the cri_index structure. See clause 7.3.3.5 for the format of this field. 



7.3.3.5 



Result locator formats 



7.3.3.5.1 



local result locator 



If the CRI results structures are located in the same container as the cri_prepend_index CRI structure that refers to them 
then the local_result_locator format may be used. The syntax of the local_result_locator structure is defined by table 42. 

Table 42: Local result locator 



Syntax 


No. of bits 


Identifier 


local result locator { 

result ptr 
} 


16 


uimsbf 



result_ptr: The offset, in bytes, from the first byte of the result_data CRI structure to the first byte of the relevant CRID 
results. 
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7.3.3.5.2 



remote result locator 



If the CRI results structures are located in a separate container than the cri_leaf_index CRI structure then the 
remote_result_locator format shall be used. The syntax of the remote_result_locator structure is defined by table 43. 

Table 43: Remote result locator 



Syntax 


No. of bits 


Identifier 


remote result locator { 
targe t_container_id 
target handle 

} 


16 
16 


uimsbf 
uimsbf 



target_container_id: The ID of the container holding the CRID content referencing result. 

target_handle: This field identifies a CRID result within the target container. This value of this field shall match the 
value of the handle_value field that corresponds to the relevant CRID result in the target container's resultsjist structure 

(see clause 7.3.3.2). 



8 



Profile of TVA metadata over DVB transport streams 



8.1 



Introduction 



The TV-Anytime metadata specification provides several options for how to structure descriptions of programme, group 
and schedule information. This clause defines the options that are either mandatory, optional or not used, for 
TV-Anytime metadata delivered over DVB transport streams. 

NOTE: The present document does not provide any profiling for metadata delivered by other means. 
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8.2 Summary 



Table 44 summarizes the use of TV-Anytime metadata types in DVB transport streams. 



Table 44: Summary of use of TV-Anytime metadata types. 



Fragment 


DVB Profile 


Programlnformation 


Required for support of metadata searching. In addition, a 
Programlnformation fragment (with the same GRID) shall be 
present for each ScheduleEvent element that does not contain 
an InstanceDescription element. Otherwise optional. 


Grouplnformation 


A Grouplnformation fragment shall be present for each group 
GRID that is referenced by other fragments. Otherwise optional. 


BroadcastEvent 


Optional. If provided then there shall be a corresponding PIT 
entry for the content item. 


Schedule 


Optional. 


Servicelnformation 


A Servicelnformation fragment shall be present for each 
servicelD referenced by other fragments. Otherwise optional. 


PersonName (from 
CreditslnformationTable) 


A PersonName fragment shall be present for each person that 
is referenced from other fragments. Otherwise optional. 


OrganizationName (from 
CreditslnformationTable) 


An OrganizationName fragment shall be present for each 
organization that is referenced from other fragments. Otherwise 
optional. 


Segmentlnformation 


Optional. 


SegmentGrouplnformation 


Optional. 


Review (from ProgramReviewTable) 


Optional. 


OnDemandProgram 


Optional. 


OnDemandService 


Optional. 


PushDownloadProgram 


Optional. 


CSAIias 


A CSAIias fragment shall be present for each CSAIias that is 
referenced from other fragments. 


ClassificationScheme 


Mandatory if any classification scheme other than those defined 
in TS 1 02 822-3-1 [4] is referenced by any other fragment. 
Otherwise optional. 


Purchaselnformation 


Optional. 



8.3 Programlnformation fragment 



When a program is a member of a series, the EpisodeOf element should be present. When a program is a member of a 
group that is not considered to be a series, the MemberOf element should be present. 

When one or more Synopsis elements are present, the length attribute for each Synopsis element shall be present. The 
programID attribute of the Programlnformation element shall contain a CRID. This GRID should be available in the 
CRI and will normally resolve to locators, but it may resolve to other CRIDs. 



8.4 Grouplnformation fragment 



The groupid attribute of the Grouplnformation element shall contain a CRID that resolves to other CRIDs and not 
locators. The Title element shall be present. When multiple synopsis elements are present, the length attribute of each 
Synopsis element shall be present. 



8.5 Schedule fragment 



The ScheduleEvent elements within the Schedule element shall be in chronological order, with the earliest item first. 
The Schedule element shall contain a start attribute that contains a time equal to or earlier to the PublishedStartTime of 
the first ScheduleEvent element and an end attribute that contains a time that is equal to or greater than the end of the 
last ScheduleEvent element. This end time is calculated by adding PublishedDuration to PublishedStartTime. Temporal 
gaps may also exist between consecutive ScheduleEvent elements. 
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The start and end times in Schedule elements shall not overlap with other Schedule elements for the same service. 
Taken together, the Schedule elements for a particular service shall form a contiguous chronological sequence. 

The PublishedStartTime and PublishedDuration elements in the ScheduleEvent element shall be used, and the 
PublishedEndTime element shall not be present. The Program element shall be present and shall contain a CRID that 
can be found in the ProgramlnformationTable and this CRID should also be present in the CRI. 

The ProgramURL element may be present, to provide an indication of the expected broadcast location. If the 
ProgramURL refers to an event delivered in a DVB transport stream it shall contain a DVB locator that refers to an 
event, using the syntax as defined in clause 6.4. The CRI shall be considered the authoritative source of CRID to 
location information. 

The InstanceMetadatald may be present and when present the same IMI shall be available in the CRI. 

8.6 Servicelnformation fragment 

Optional elements that are absent in a Servicelnformation element may be taken from DVB-SI information. 

The ServiceURL element shall be present and shall contain a valid DVB locator that refers to a service, using the syntax 
as defined in clause 6.4. 

The Name element shall either be an empty element, or contain the same name as specified by the SDT sub_table for 
that service. If the Name element is empty, its contents shall be inferred from the SDT sub_table for that service. 

If the Logo element is present, it shall contain a URL that points to an image file. 

8.7 Segmentlnformation and SegmentGrouplnformation 
8.7.1 Referencing time 

Each segment within TV-Anytime metadata is defined within the context of a particular item of content, identified by 
its CRID. The temporal definition of the segment is relative to a timebase, which may be explicitly defined in the 
metadata. To make the link between a segmentation metadata timebase and a particular broadcast timeline delivered as 
synchronized auxiliary data, the content labelling descriptor shall be used in the Synchronized Auxiliary Data (SAD) 
and the PMT for the DVB service carrying the content, as defined in clauses 5.3.8.1 and 5.3.8.2, respectively. 

A timebase is explicitly defined using the timebaseld attribute of the TimeBaseReference element. If present this 
attribute may be in the Segmentlnformation, or it may be inherited from the encompassing SegmentGrouplnformation 
fragment (see TS 102 822-3-1 [4], clauses 6.6.5 and 6.6.6). 

The following two paragraphs relate to content labelling descriptors carried in the synchronized auxiliary data: 

If for an item of content identified by a CRID the content labelling descriptor references a time base mapping descriptor 
(see TS 102 823 [21], clause 5.2.3), then the timebaseld attribute of the TimeBaseReference element shall be defined 
for Segmentlnformation fragments defined within that content. If this is the case then the timebaseld attribute shall be 
formatted as defined in table 45. 

If for an item of content identified by a CRID the content labelling descriptor does not reference a time base mapping 
descriptor, but instead identifies a value of broadcast_timeline_id directly, then any information carried in the 
timebaseld attribute of the TimeBaseReference element shall be ignored. 
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8.7.2 DVB timebaseld attribute format 

Table 45 defines the DVB specific encoding of the timebaseld attribute. 

Table 45: timebaseld format 



timebaseld 


= "dvbtb: " dvb 


time base id 






dvb time base id 


= hex hex 








hex 


= digit 1 "A" 


"B" 1 "C" 1 "D" 


1 "E" 


1 "F" 1 




"a" "b" 


' c " " d " " e " 


"f" 




digit 


= "0" "1" 
„ 7 „ „ 8 „ 


'2" "3" "4" 


"5" 1 


"6" 1 



dvb_time_base_id: This field is a two digit hexadecimal value which shall be set to a value of time_base_id carried in 
the relevant time base mapping descriptor, if one is present. If the time base mapping descriptor is present then the 
encoded value of dvb_time_base_id shall map to the correct broadcast timeline for this Segmentlnformation or 
SegmentGroupInformation fragment. 

8.7.3 mediaTimeUnit and mediaTimeBase attributes 

The mediaTimeBase attribute is not used by the present document. 

NOTE: The mediaTimeBase attribute may be present, for example, in elements of type 

mpeg7:MediaRelIncrTimePointType. If this attribute is found receivers may ignore it. 

Table 46 defines values of mediaTimeUnit attribute which shall be used if temporal information in Segmentlnformation 
or SegmentGroupInformation fragments is encoded using elements of type mpeg7:MediaRelIncrTimePointType or 
mpeg? : MedialncrDurationType . 

Table 46: mediaTimeUnit format 



tick format 


Frame rate 


Value of mediaTimeUnit 


0000 0001 


24 000/1 001 (23,976...) 


PT1001N24000F 


0000 0010 


24 


PT1N24F 


0000 0011 


25 


PT1N25F 


0000 0100 


30 000/1001 (29,97...) 


PT1001N30000F 


0000 0101 


30 


PT1N30F 


0000 0110 


50 


PT1N50F 


0000 0111 


60 000/1 001 (59,94...) 


PT1001N60000F 


0000 1000 


60 


PT1N60F 


0001 0000 


1 000 ticks/sec 


PT1N1000F 



8.8 BroadcastEvent fragment 



The BroadcastEvent fragment can be used to announce the availability of items of content for which the time of 
broadcast is outside the schedule period. Its use is optional. 

The PublishedStartTime and PublishedDuration elements in the BroadcastEvent element may be present, but the 
PublishedEndTime element shall not be present. The Program element shall be present and shall contain a GRID that 
can be found in the ProgramlnformationTable. Initially this GRID may not be present in the GRI. 

Where a BroadcastEvent and ScheduleEvent referring to the same item of content and broadcast instance co-exist in the 
same metadata description they shall contain identical data and the servicelD in BroadcastEvent shall be identical to the 
servicelD in the parent Schedule fragment of the equivalent ScheduleEvent. 

When a ScheduleEvent for which there is an equivalent BroadcastEvent (i.e. referring to the same content item and 
broadcast instance) is inserted into the metadata description then the BroadcastEvent should be removed before the time 
of broadcast of the content item. 

The locator carried in the ProgramURL element and the GRI can be populated in terms of the actual broadcast location 
at any time after the addition of the BroadcastEvent fragment. 
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8.9 TVAMain 

The delivery of TVAMain and the defauh TVMain fragment is defined by clause 9.4.2.2. 

The publisher attribute may be present, if so it shall be encoded as defined below. Use of this attribute is recommended. 

NOTE 1 : Use of this attribute allows the receiver to easily determine the source of the metadata for presentation 
purposes. This could allow the user to, for example, distinguish between metadata for the same content 
provided by different metadata providers. 

The format of the publisher attribute has two parts, the first part is a domain name identifying the metadata provider, 
and the second part is a readable name of a form suitable for presentation to the user. The descriptive text shall be 
encoded according to RFC 3986 [2] and may contain encoded representation of space, slash, etc. 

• <domain_name> "/" <readable_name> 
For example: 

• "tvlisrings.tv/TV%20Listings". 

NOTE 2: The present document does not define rules regarding how a receiver should manage multiple metadata 
services from the same metadata provider. Possible complexities exist, for example where different 
metadata services from the same metadata provider offer different levels of detail about the same content. 



8.10 Generic rules 



Elements of type anyURI, as defined by XML Schema Part 2: Datatypes [16], may contain a DVB locator (see 
clause 6.4). 



Delivery of metadata 



9.1 Introduction 

The TV-Anytime forum has defined how metadata shall be encoded and encapsulated for delivery over a unidirectional 
network (see TS 102 822-3-2 [5]). 

There are several aspects to this technology (see TS 102 822-3-2 [5], clause 4.2): 

• Fragmentation: splitting the metadata document into a number of self-contained fragments. 

• Encoding: binary encoding of fragments for efficient delivery. 

• Encapsulation: structures for identification of fragments and concatenation of fragments into containers. 

• Indexing: structures for identification of fragments according to the value of an attribute or element. 

Both metadata and indices are carried in containers. However, TS 102 822-3-2 [5] does not define how containers are to 
be delivered in a particular environment, such as DVB transport streams. In clause 4.5.1 of TS 102 822-3-2 [5] the 
following requirements are defined for the carriage of containers: 

• Containers are to be classified into data containers or index containers (or containers that carry both). 

• Containers are to be identifiable by a 16 bit identifier. 

This clause defines how TV-Anytime metadata may be encoded and delivered on DVB transport streams. This clause 
implements TS 102 822-3-2 [5] and defines a number of additional extensions and constraints. These include: 

• Carriage of metadata containers by object carousel, including classification and identification. 

• Additional semantics for encapsulation of fragments. 
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• Additional semantics and codecs for encoding of fragments using BiM. 

• A set of profiled indices. 

9.2 Delivery of containers 

9.2.1 Delivery by MHP object carousel 

The metadata_pointer_descriptor and the metadata_descriptor both contain a DVB_carriage_format field, which signals 
the transport protocol being used for the metadata service being described (see clause 5.3.4). If the value of this field is 
set to 0x00 then the metadata shall be delivered in an object carousel compliant with the object carousel profile as 
defined in annex B of TS 102 812 [11] with the additional constraints defined in this clause. 

Containers, as defined in TS 102 822-3-2 [5], clause 4.5.1, shall be carried within B10P::FileMessages (file objects). 
All containers for a single metadata service shall be referenced from the root directory (B10P::DirectoryMessage or 
BIOP::ServiceGatewayMessage) for that metadata service, as indicated by the relevant metadata descriptor (see 
clause 5.3.4). Containers for a metadata service shall not be carried in sub-directories of the directory signalled by the 
metadata descriptor for that metadata service. One object carousel may contain several metadata services. 

Since the MHP profile of the object carousel provides a number of features that are not required for the delivery of TVA 
metadata, within the context of the present document the constraints defined in table 47 shall be observed. 

Table 47: MHP object carousel constraints 



MHP Section 




B.2.2.4.1 


Label descriptor 


Not used by the present document (see note). 


B.2.2.4.2 


Caching priority descriptor 


Not used by the present document (see note). 


B.2.3.4 


Content type descriptor 


Not used by the present document (see note). 


B.2.3.7.2 


LiteOptionsProfileBody 


All containers of a metadata service shall be carried in a single 
object carousel. Therefore, LiteOptionsProfileBody may not 
form part of the reference to any such container. However, 
external assets, e.g. images, audio clips, referenced by the 
metadata service may be delivered in a different object 
carousel, the LiteOptionsProfileBody may be used as part of 
the reference to any such external assets. 


B.2.3.8 


BlOP StreamlVlessage 


Not used by the present document (see note). 


B.2.3.9 


BlOP Stream EventMessage 


Not used by the present document (see note). 


B.2.4 


Stream Events 


Not relevant to the present document. 


B.2.10.2 


DVB-J mounting of an object 
carousel 


Not relevant to the present document. 


B.3.2 


DSM-CC associationjags to 
DVB componentjags 


All Oils and DDBs used in the delivery of a metadata service 
shall be carried in elementary streams that are listed in the 
PMT that carries the metadata descriptor for that metadata 
service (see clause 5.3.5). Therefore, use of the 
deferred association tags descriptor is not required. 


B.3.1.2 


TapUse is 

BlOP PROGRAM USE 


Not used by the present document (see note). 


B.5 


Caching 


Informative for receiver manufacturers. 


NOTE: Metadata services shall not include such information in the object carousel. Receivers may 
ignore the presence of such information in the object carousel when accessing metadata 
services. 
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9.2.2 Container identification 

The format for the file name for container files (i.e. the format of the NameComponent ID given in the binding that 
references a container file) is defined by table 48. 

Table 48: File name format for container files 



container file name 


= mapped container 


id 




classification indicator 




mapped container id 


= hex string 












classification indicator 


="d" 1 "i" 1 "b 


' 










hex string 


= 4*hex 












hex 


= digit 1 "A" 
"d" 1 "e" 1 


"B' 


' 


'C" 


1 "D" 1 "E" 1 "F" 1 "a" 1 "b" 


1 "c" 1 


digit 


= "0" 1 "1" 1 


'2" 


"3 


' 1 


"4" 1 "5" 1 "6" 1 "7" 1 "8" 1 


"9" 



The mapped_container_id carries the container ID for this container expressed as a hex_string. If present, the index list 
structure (see clause 9.5.1.3) shall be carried in a container with container_id set to 0x0000. 

The classification_indicator is a single character that indicates the classification of the container (see 
TS 102 822-3-2 [5], clause 4.5.1.2). It shall be encoded according to table 49. 

Table 49: Classification indicator 



Value 


Semantics 


"d" 


The container is a data container. 


"1" 


The container is an index container. 


"b" 


The container is both a data container and an index container. 


Other values 


Reserved. 



Table 50 contains example file names. 



Table 50: Example file names 



Example 


Container ID 


Container classification 


"001 F.d" 


0x001 F 


Data container. 


"0DB6.b" 


0x0DB6 


Data container and index container. 


"OOOO.i" 


0x0000 


Index container which carries index list. 



9.3 Fragment encapsulation 



9.3.1 



Introduction 



TS 102 822-3-2 [5], clause 4.6 defines how fragments shall be encapsulated within containers. As part of that 
encapsulation the encapsulation structure uses fragment references as a means to reference fragments and provide 
version information for those fragments. The present document defines a DVB BiM fragment reference, which is 
necessary for supporting the dvbStringCodec defined in clause 9.4.3.3. The DVB BiM fragment reference differs from 
the fragment reference defined in TS 102 822-3-2 [5] by containing an additional external string buffer reference. 
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Figure 10 illustrates the format of a data container where the encapsulation structure uses the DVB fragment reference. 



Container 
Header 




Encapsulation 
structure 






Fragment 1 
Fragment 2 






-^ 




String Data 
Repository 

Fragment 2 String 
Fragment 1 String 


^ 
-^ 




< 


Binary Data 

Repository (BiM 

fragments) 

Fragment 1 Data 

Fragment 2 Data 


^ 





Figure 10: Example illustrating container when using DVB fragment references 

9.3.2 Encapsulation structure 

This clause defines additional semantics of fields of the encapsulation structure as defined in TS 102 822-3-2 [5], 
clause 4.6.1.1. 

fragment_reference_format: This field defines the format and the interpretation of the fragment_reference field. This 
field shall be encoded according to table 5 1 . 

Table 51 : Fragment reference format 



Value 


Semantics 


0x00 to OxEO 


Defined by TS 1 02 822-3-2 [5], clause 4.6.1.1 


OxE1 


DVB BiM fragment reference 


0xE2 to OxEF 


DVB Reserved 


OxFO to OxFF 


User defined 



If a container carries fragments that use the dvbStringCodec then the fragment_reference_format field shall be set to 
OxEl. 

9.3.3 DVB BiM fragment reference 

The format of the DVB BiM fragment reference is defined by table 52. 

Table 52: DVB BiM fragment reference 



Syntax 


No. of bits 


Mnemonic 


DVB BiM fragment reference {) { 
BiM fragment_ptr 
external string buffer ptr 
} 


16 
16 


uimsbf 
uimsbf 



BiM_fragment_ptr: The zero-based offset in bytes from the start of the binary repository within this container to the 
first byte of the FragmentUpdateUnit() enclosing the intended fragment. 
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external_string_buffer_ptr: The zero-based offset in bytes from the start of the string repository within this container 
to the first byte of the external string buffer for the fragment. 

The structure of the data repositories of type string data (or "string repository") is specified in TS 102 822-3-2 [5], 
clause 4.8.4.1. The structure of the data repositories of type binary data (or "binary repository") is defined in 
clause 9.4.3.2 of the present document. 



9.4 Fragment encoding 



9.4.1 



Introduction 



In order to simplify the implementation of BiM decoders and to improve the compression of TV-Anytime fragments, 
the present document imposes a number of restrictions on the TVA MPEG-7 BiM profile, as defined in 
TS 102 822-3-2 [5]. 

9.4.2 Rules for BilVI encoding 



9.4.2.1 



DVB-TVA-init Message 



The present document defines a DVB profile of the TVA MPEG-7 profile defined in TS 102 822-3-2 [5]. A new 
encoding version is introduced and a number of restrictions have been imposed on the initialization of the BiM 
decoders. The DVB-TVA-init message shall be delivered as specified in clause 5.3.4. The DVB-TVA-init message is 
adapted from the TVA-init message defined in TS 102 822-3-2 [5], clause 4.4.1, it shall be encoded according to 
table 53. 

Table 53: DVB-TVA-init 



Syntax 


No. of bits 


Mnemonic 


DVB-TVA-init { 






EncodingVersion 


8 


uimsbf 


IndexingFlag 


1 


bslbf 


reserved 


7 




Decoder Initptr 


8 


bslbf 


if ( EncodingVersion == '0x01' | | 






EncodingVersion == ' OxFO ' ) { 






Buf ferSizeFlag 


1 


bslbf 


PositionCodeFlag 


1 


bslbf 


reserved 


6 




CharacterEncoding 


8 


uimsbf 


if (Buf ferSizeFlag == '1') { 






Buf f erSize 
} 


24 


uimsbf 


} 

if (IndexingFlag) { 






IndexingVersion 

} 
Reserved 


8 


uimsbf 


0or8+ 




Decoderlnit ( ) 
} 




bslbf 



The semantic of all terms of the DVB-TVA-init message is as defined for the TVA-init message defined in 
TS 102 822-3-2 [5], excepted for the PositionCodeFlag and EncodingVersion fields. 
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EncodingVersion: This field indicates the method of encoding used to represent the TVA metadata fi"agments. This 
field shall be encoded according to table 54. 

Table 54: EncodingVersion 



Value 


Encoding Version 


0x00 to OxEF 


TVA reserved. 


OxFG 


DVB profile of TVA MPEG_7 profile (BiM) 

ISO/IEC 15938-1 [10] as defined in the present document. 


OxF1 to 0xF7 


DVB reserved. 


0xF8 to OxFF 


User defined. 



PositionCodeFlag: This field indicates if the BiM contextPath Position Code is used in the encoded fragment. This 
field shall be set to '0'. 

NOTE 1: This value indicates that the position code is not used within the contextPath, as defined in clause 9.4.2.3. 
This means that the canonical format of the instance description is not preserved, i.e. the relative ordering 
of fragments is not preserved. 

CharacterEncoding: This field shall be encoded as defined by TS 102 822-3-2 [5], clause 4.4.1. 

NOTE 2: For compatibility it is advised that receivers should at least support the UTF-8 character encoding format. 



9.4.2.2 



Decoderlnit and default TVAMain fragment 



In BiM, the Decoderlnit is used to configure parameters required for the decoding of the binary fragments and to 
transmit the initial state of the decoder. 

At least one schema URN shall be transmitted in the Decoderlnit. Consequently, the field NumberOfSchemas of the 
Decoderlnit shall be greater or equal to 1 and the field SchemaURI[0] of the Decoderlnit shall be set to 
"urn:tva:metadata:2004", indicating the use of the schema defined by TS 102 822-3-1 [4]. 

The initial state of a BiM decoder for a binary description tree is given by an initial description. In a TVA fragment 
stream, the initial description is given by the TVAMain fragment. 

In the present document, the transmission of the initial description to the decoder is not mandatory. If the TVAMain 
fragment is not delivered to the decoder, the decoder is initialized with a default TVAMain fragment. The default 
TVAMain fragment is defined in table 55. 

Table 55: Default TVAMain fragment 



<TVAMain ;:mlns= 'urn: tva: metadata: 2 04 ' > 


<Classif icationSchemeTable /> 


<ProgramDescription> 


<ProgramInf ormationTable /> 


<GroupInf ormationTable /> 


<ProgramLocationTable /> 


<ServiceInf ormationTable /> 


<CreditsInf ormationTable /> 


<ProgramReviewTable /> 


<SegmentInf ormationTable > 


<SegmentList /> 


<SegmentGroupList /> 


</ Segment Inf ormationTable > 


<PurchaseInf ormationTable /> 


</ProgramDescription> 


</TVAMain> 



If the TVAMain fragment is delivered to the decoder, it shall be encapsulated in a data container as defined in 
clause 9.3, and this container shall be delivered as defined in clause 9.2 with the following restriction; the name of the 
file name for the container which conveys the TVAMain fragment shall be "tvamain". 

As a consequence, the InitialDescriptionQ field of the Decoderlnit message as specified in ISO/IEC 15938-1 [10], shall 
always be empty. 

For the DVB profile of TVAMain see clause 8.8. 
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9.4.2.3 



DVB BiM access unit 



In BiM, a path is encoded at the beginning of each fragment. This path specifies the type of the element encoded in the 
fragment. The TVA MPEG-7 BiM profile specify the fixed set of possible TV- Anytime fragments. The present 
document replaces the resulting ContextPath expressions in the fragment encoding, whose format is defined in 
ISO/IEC 15938-1 [10], clause 7.6.5, by a set of fixed ContextPath values identifying the type of the TVA fragments. 

As a consequence, the definition of the binary_ repository table as specified in TS 102 822-3-2 [5], clause 4.6.1.4.1.1 is 
profiled according to table 56. 

Table 56: binary repository carrying DVB BilVI access unit 



Syntax 


No. of bits 


Identifier 


binary repository {) { 






DVBBiMAccessUnit { 






NumberOfFUU 


8+ 


vluimsbf8 


for(i=0; i< NumberOfFUU; i++) { 






FUULength 


8+ 


vluimsbf8 


DVBContextPath 


16 


uimsbf 


FragmentUpdatePayload (startType) 
} 






} 

for {i=0; i<N; i++) { 






private byte 
} 
} 


8 


uimsbf 



startType: This flag is set to the EquivalentStartType associated to the value of the DVBContextPath flag as defined in 
table 57. 

FragmentUpdatePayload: Triggers the decoding of the TV-anytime fragment of type startType as defined in 
ISO/IEC 15938-1 [10], clause 8.3. 

DVBContextPath: This field identifies the type of the fragment. It shall be encoded according to table 57. This table 
defines the DVBContextPath value for each fragment type defined in clause 8. The DVBContextPath values are 
identical to the Fragment_type values defined in TS 102 822-3-2 [5], table 7. The EquivalentStartType type names are 
namespace qualified and use the following namespace prefix: 



tva 



urn:tva:metadata:2004 



Table 57: DVBContextPath 



Value 


Description 


EquivalentStartType 


0x0000 


reserved 




0x0001 


Programlnformation fragment 


tva:ProgramlnformationType 


0x0002 


Grouplnformation fragment 


tva:GrouplnformationType 


0x0003 


OnDemandProgram fragment 


tva:OnDemandProgramType 


0x0004 


BroadcastEvent fragment 


tva:BroadcastEventType 


0x0005 


Schedule fragment 


tva:ScheduleType 


0x0006 


Servicelnformation fragment 


tva:ServicelnformationType 


0x0007 


PersonName fragment 


tva:TVAPersonNameType 


0x0008 


OrganizationName fragment 


tva:OrganizationNameType 


0x0009 


Review fragment 


tva:ReviewType 


OxOOOA 


CSAIias fragment 


tva:GSAIiasType 


OxOOOB 


ClassificationScheme fragment 


tva:ClassificationSchemeType 


OxOOOC 


Segmentlnformation fragment 


tva:SegmentlnformationType 


OxOOOD 


SegmentGrouplnformation fragment 


tva:SegmentGrouplnformationType 


OxOOOE 


TVAMain fragment 


tva:TVAMainType 


OxOOOF 


OnDemandService fragment 


tva:OnDemandServiceType 


0x0010 


Purchaselnformation fragment 


tva:PurchaselnformationType 


0x001 1 to 0x0021 


TVA defined (TS 102 822-3-2 [5], table 7) 




0x0022 


PushDownloadProgram fragment 


tva:PushDownloadType 


0x0023 to OxOOEF 


DVB Reserved 




OxOOFO to OxFFFF 


User defined 
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9.4.3 Codec definitions 

9.4.3.1 Introduction 

The present document defines a set of codecs that shall be used by default for the encoding of TV-Anytime fragment in 
the DVB-GBS context. 

9.4.3.2 Classification scheme of DVB Codecs 

In the MPEG-7 framework, the use of a specific codec for a specific type is signalled using the codec configuration 
mechanism defined in ISO/IEC 15938-1 [10]. This mechanism associates a codec using its URI with a list of schema 
types. For that purpose, a URI is assigned to each codec in a classificationScheme, which defines the list of the specific 
codecs. 

In the present document, this list is composed of the following codecs: dvbStringCodec, dvbDateTimeCodec, 
dvbDurationCodec, dvbLocatorCodec, and dvbControlledTermCodec. Figure 1 1 gives the standard 
ClassificationScheme used by the present document. 



<Classif icationScheme uri= "urn :dvb: metadata: cs :CodecTypeCS : 2 004 "> 
<Term termID="l"> 

<Name xml : lang="en" >dvbStringCodec</Name> 

<Definition xml : lang="en">Encodes string by using an external string 
buf fer</Def inition> 
</Term> 
<Term t:ermiU="2"> 

<Name xml : lang= "en" >dvbDateTimeCodec</Name> 

<Definition xml : lang="en">Encodes date using Modified Julian Date & Time in 
Millisecond and differential encoding</Def inition> 
</Term> 
<Term termID="3"> 

<Name xml : lang="en">dvbDurationCodec</Name> 

<Definition xml : lang="en">Encodes duration using strings or 
approximation with an accuracy of 1 minute </Def inition> 
</Term> 
<Term termlU="4"> 

<Name xml : lang= "en" >dvbLocatorCodec</Name> 

<Definition xml : lang="en">Encodes DVB Locator using prefix dictionary </Def inition> 
</Term> 
<Term termID="5"> 

<Name xml : lang="en">dvbControlledTermCodec</Name> 

<Definition -iml : lang= "en">Encodes Controlled Terms using indices</Def inition> 
</Term> 
< /Class ificationScheme> 



Figure 1 1 : DVB codec classification 

9.4.3.3 dvbStringCodec 

9.4.3.3.1 Introduction 

The dvbStringCodec codec, as defined in this clause, may be used for the encoding of strings. 

9.4.3.3.2 Rationale and encoding process (informative) 

9.4.3.3.2.1 Rationale 

Most TV-Anytime fragments are likely to have a rather small size. This implies a limited redundancy over the string 
data, and therefore the efficiency of the zlibCodec string codec, as specified by TS 102 822-3-2 [5], might be poor. On 
another hand some redundancy in the strings across different fragments can be expected. Therefore, to achieve good 
compression ratio, the optimized dvbStringCodec codec gather the strings of all binary fragments of a TV-Anytime 
container in a single string repository within this container. The delivery method used for carrying the TV-Anytime data 
containers applies a compression method to the whole container. For instance, a metadata container may be transmitted 
within a compressed object carousel module. Therefore the statistical compression can take advantage of the inter- 
fragment redundancy. 



ETSI 



63 



ETSI TS 102 323 V1.5.1 (2012-01) 



9.4.3.3.2.2 



Encoding 



At the encoding time, the dvbStringCodec gathers all the strings from a BiM fragment in an external string buffer. The 
external string buffers of all fragments of a TV-Anytime container shall be stored in a string repository in the same 
container. This dvbStringCodec is reinitialized for each TV-Anytime fragment. The syntax of the string repository is as 
specified in TS 102 822-3-2 [5], clauses 4.6.1.4 and 4.8.4.1. 

Figure 12 represents how a regular BiM bitstream can be converted into a BiM bitstream as supported by the present 
dvbStringCodec and its associated external string repository. 

Strings 





Regular BiM bitstream 



a 



BiM Fragment 



External string 
Buffer 




BiM bitstream with 
external string buffer 

Figure 12: BiM bitstream with an external string buffer 

The external string buffers are sets of consecutive strings separated by a string_terminator as defined 
TS 102 822-3-2 [5], clause 4.8.4.1. 



9.4.3.3.2.3 



Decoding principle 



The principle of the decoding a BiM fragment with an external string buffer is the same as the decoding of a regular 
BiM bitstream. The main difference so far is that the string codec is reading the string data from the external string 
buffer instead of reading the strings from the main regular BiM bitstream. 

At the beginning of the decoding of a BiM Fragment unit, the string codec is initialized with a reference to the first byte 
of the first string of the external string buffer. 



9.4.3.3.2.4 



Managing sclnema compatibility and skippable chunks 



Things get a bit complicated when one want the string codec to support schema compatibility (in that case, the decoder 
can skip extended elements, see clause 9.4.4) or allow the user to skip parts of the bitstream. Indeed, at decoding time 
after a chunk of the bitstream is skipped, the string codec must be re-synchronized at the appropriate place in the 
external string buffer. 

This is done by inserting in the BiM bitstream, for each string immediately following the end of a skippable element, 
the offset of this string in the external string buffer. When decoding the string, the decoder reads this offset and uses it 
to re-synchronize the string codec at the appropriate location in the external string buffer. 

Figure 13 illustrates how the bitstream shall be encoded in order to support the skip of an element which preceded a 
string element. 
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skippable element 



\ 



Offset of the first string 
following the end of the 
skippable element 



_x_ 



BiM Fragment 



External string 
Buffer 



BiM bitstream with 
external string buffer 

Figure 13: BiM bitstream with a sitippable element before a string element 



9.4.3.3.3 Decoding 

The format for this codec is defined in table 58. 

Table 58: dvbStringCodec 



Syntax 


No. of bits 


Identifier 


dvbStringCodec () { 

if ( isFollowingSkippableElement == 1) { 
string offset 
resynchronizeCodec (string offset) 

} 

getNextStringFromBuf f er ( ) 

} 


16 


uimsbf 



isFollowingSkippableElement: This field shall be set to '1' when the decoder is decoding the first of the strings 
following the end of a skippable element. In this case, this means that the offset of this string in the external string 
repository shall be read in the bitstream. 

string_offset: The offset in bytes, from the beginning of the external string buffer, of the first character of the string 
being decoded. 

resynchronizeCodec(string_offset): Synchronizes the dvbStringCodec on the first byte, in the external string buffer, of 
the string to be decoded. The offset, in bytes, from the beginning of the external string buffer, is given by the 
string_offset parameter. 

getNextStringFromBuffer(): Reads the current string in the external string buffer, and jumps to the first byte of the 
next string of the buffer. 



9.4.3.4 



dvbLocatorCodec 



9.4.3.4.1 



Usage 



The dvbLocatorCodec is used by default for the encoding of elements or attributes of type anyURI in order to 
efficiently encode the DVB Locator as defined in clause 6.4. 



9.4.3.4.2 



Rationale and encoding process (informative) 



Within a single TV- Anytime fragment a given DVB locator prefix, composed of the original networks ID, a transport 
stream ID and a service ID, is often reused by several CRIDs. In order to efficiently encode this repetition, the 
dvbLocatorCodec reuses the prefix of the decoded DVB locator which it is immediately preceding in the fragment if it 
has the same prefix. 
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9.4.3.4.3 Decoding 

The format of the DVBLocatorCodec is defined by table 59. 



Table 59: DVBLocatorCodec 



Name 


No. of bits 


Identifier 


DVBLocatorCodec { ) { 

optimized_codec_f lag 

if {optimized_codec flag ==1) { 

OptimizedDVBLocator { ) 
} else { 

dvbStringCodec { ) 
} 
} 


1 


bslbf 



optimized_codec_flag: A flag which indicates whether the optimized codec is used or not. If not, the default string 
encoding codec is used. 

dvbStringCodec(): For the definition of the dvbStringCodecQ see clause 9.4.3.3. 

OptimizedDVBLocator(): This field encodes the DVB locator in an optimized way. The format for this field is defined 
by table 60. 

Table 60: OptimizedDVBLocator 



Name 


No. of bits 


Identifier 


OptimizedDVBLocator { ) { 






prefix flag 


1 


bslbf 


if {prefix_flag ==1) { 






DVBLocatorPref ix { ) 

} 

ctag flag 






1 


bslbf 


if {ctag_flag ==1) { 






for {i=0;i<N;i++) { 






component tag 


8 


uimsbf 


ctag continue 
} 


1 


bslbf 


} 

cid flag 


1 


bslbf 


if (cid_flag ==1) { 






carousel id 

} 

eventOrTVAf lag 


32 


uimsbf 


2 


bslbf 


if {eventOrTVAflag == 01) { 






event id 

} 

else if {eventOrTVAflag ==10) { 


16 


uimsbf 






TVA id 

} 

time flag 


16 


uimsbf 


1 


bslbf 


if {time_flag = 1) { 






day flag 


1 


bslbf 


if {day_flag =1) { 






day 

} 
time 


16 


uimsbf 


17 




duration 

} 

path segments flag 


17 




1 


bslbf 


if {path segments flag ==1) { 






path segments {) 
} 
} 
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prefix_flag: If the prefix_flag is set to '1' the DVBLocatorPrefix is encoded. For the first occurrence in the fragment, 
this flag shall be set to 1 . For subsequent occurrences, the prefix_flag may be set to '0' in which case the previous value 
of DVBLocatorPrefix encoded in this fragment is reused. 

If this field is set to '1' within a skippable encoded chunk relating to a schema extension, then the next occurrence of this 
codec outside of that encoded chunk shall set this field to '1'. For extending the TV-Anytime schema see clause 9.4.4. 

NOTE 1 : This is to prevent problems with the reused information being set in part of the BiM bitstream 

inaccessible by a receiver that does not understand the extended schema. This receiver would use the 
wrong value of the reused information for the next occurrence. 

DVBLocatorPrefix: This field encodes the original_network, the transport_stream and the service_id. If the 
transport_stream_id field is set to 0x0000 then it shall be ignored and the DVB service shall be uniquely identified by a 
combination of original_network_id and service_id. The format of this field is defined by table 61. 

Table 61 : DVBLocatorPrefix 



Name 


No. of bits 


Identifier 


DVBLocatorPref ix{) { 
transport stream id 
original network id 
service id 

} 


16 
16 
16 


uimsbf 
uimsbf 
uimsbf 



transport_streain_id: This field shall be set to the numerical value of transport_stream_id in the DVB locator being 
encoded (see clause 6.4). If the transport_stream_id field is not present in the DVB locator this field shall be set to 
0x0000. 

original_network_id: This field shall be set to the numerical value of transport_stream_id in the DVB locator being 
encoded (see clause 6.4). 

service_id: This field shall be set to the numerical value of service_id in the DVB locator being encoded (see 
clause 6.4). 

ctag_flag: This field shall be set to '1' if one or more component_tags structures are present. Otherwise this field shall 
be set to '0'. 

If the eventOrTVAFlag is set to '10', denoting that the TVA_id is encoded then: 

• If the TVA_id identified will be carried in PES (see clause 11.2.3) the ctag_flag shall be set to '1'. The 
component_tags() field shall contain a single component_tag value identifying this PES component. 

• If the TVA_id identified will be carried in FIT (see clause 1 1 .2.2) the ctag_flag shall be set to '0'. 

component_tag: This field shall be set to the numerical value of the corresponding component_tag in the DVB locator 
being encoded (see clause 6.4). 

ctag_continue: This field shall be set to '0' if this is the last component_tag to be encoded. Otherwise it shall be set to 

'1'. 

cid_flag: This field shall be set to '1' if the carousel_id field is present. Otherwise it shall be set to '0'. 

carousel_id: This field shall be set to the numerical value of carousel_id in the DVB URL being encoded. 

eventOrTVAFlag: This field indicates if an event_id or a TVA_id or none of them is encoded. This field shall be 
encoded according to table 62. 

Table 62: eventOrTVAFlag 



Value 


Description 


'00' 


event-id and TVA-id are not encoded 


'01' 


event id is encoded 


'10' 


TVA id is encoded 


'11' 


reserved 
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time-flag: This flag shall be set to '1' if time information is encoded. Otherwise it shall be set to '0'. 

day_flag: If the day_flag is set to '1', the day is encoded. For the first occurrence in a fragment this flag shall be set 
to '1'. For subsequent occurrences the day_flag may be set to '0' in which case the previous value of day encoded in this 
fragment is reused. 

If this field is set to '1' within a skippable encoded chunk relating to a schema extension, then the next occurrence of this 
codec outside of that encoded chunk shall set this field to '1'. For extending the TV-Anytime schema see clause 9.4.4. 

NOTE 2: This is to prevent problems with the reused information being set in part of the BiM bitstream 

inaccessible by a receiver that does not understand the extended schema. This receiver would use the 
wrong value of the reused information for the next occurrence. 

day: The date to which this locator refers. This field is coded as 16 bits giving the 16 LSBs of MJD. See 
EN 300 468 [1], annexe. 

time: The time of day to which this locator refers. This field is represented using 17 bits expressed as the number of 
elapsed seconds since midnight. 

duration: Is represented using 17 bits expressed as the number of elapsed seconds. 

path_segments(): This field encodes the path_segments component of the dvbLocator in a string representation. The 
format of this field is defined by table 63. 

Table 63: path_segments 



Name 


No. of bits 


Identifier 


path segments {) { 

dvbStringCodec { ) 
} 







dvbStringCodec(): For the definition of the dvbStringCodec see clause 9.4.3.3. 

9.4.3.5 dvbDateTimeCodec 

9.4.3.5.1 Rationale and encoding process (informative) 

The XML Schema primitive simple type dateTime is used widely within the TVA metadata Schema, and so a specific 
codec has been designed to represent date time elements or attributes. 

Times shall be based on UTC, with no provision provided for maintaining the local time offset information. Any 
requirement to localize time values shall be performed by the receiving terminal. 

The dateTime type is used by the following TV-Anytime types: TVAMainType, ScheduleType, ScheduleEventType, 
OnDemandProgramType, and ServiceRefType. 

Within a single TV-Anytime fragment a given date is often reused. In order to efficiently encode this repetition, the 
dvbDateTimeCodec can reuse the value of the immediately preceding date instead of re -encoding it. 

When the date is different from the previously encoded one, the date is represented using 2 bytes as a Modified Julian 
Date. 

In order to further improve the compression ratio of dateTime elements or attributes, the time information are 
represented using 1 1 bits, with an accuracy of 1 minute. 
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9.4.3.5.2 Decoding 

The format of the dvbDateTimeCodec is defined by table 64. 

Table 64: dvbDateTimeCodec 



Name 


No. of bits 


Identifier 


dvbDateTimeCodec { ) { 






dateTime_Flag 


2 


bslbf 


if {dateTime flag==00) { 






dateTimeOfTVA 

} 

if {dateTime flag==01) { 


64 


bslbf 






PublishedTime {) 
} 
} 







dateTime_flag: This flag is used to state the encoding mode of the dateTime element or attribute. When an accuracy of 
one minute is sufficient, publishedTime() should be used. PublishedTime() is recommended for encoding the 
publishedStartTime and publishedEndTime sub-elements of the ScheduleEventType type. This field shall be encoded 
according to table 65. 

Table 65: dateTime_flag 



value 


Semantic 


00 


the dateTime codec as defined in 

TS 102 822-3-2 [5], clause 4.4.2.4.2 is used 


01 


A published time is encoded 


10 to 11 


reserved 



dateTimeOfTVA: The dateTime elements or attributes shall be encoded with the dateTimeCodec as defined in 

TS 102 822-3-2 [5], clause 4.4.2.4.2. 

PublishedTime(): Optimized encoding of the dateTime elements or attributes as defined in the present document. This 
field shall be formatted according to table 66. 

Table 66: PublishedTime 



Name 


No. of bits 


Identifier 


PublishedTime { ) { 






date flag 


1 


bslbf 


if {date_flag == 1) { 






date 

} 
time 

} 


16 


bslbf 


11 


uimsbf 



date_flag: If this field is set to '1', the date is encoded. For the first occurrence in the fragment, this field shall be set to 
'1'. For subsequent occurrences, the date_flag field may be set to '0' in which case the previous value of date encoded in 
this fragment is reused. 

If this field is set to '1' within a skippable encoded chunk relating to a schema extension, then the next occurrence of this 
codec outside of that encoded chunk shall set this field to '1'. For extending the TV-Anytime schema see clause 9.4.4. 

NOTE: This is to prevent problems with the reused information being set in part of the BiM bitstream 

inaccessible by a receiver that does not understand the extended schema. This receiver would use the 
wrong value of the reused information for the next occurrence. 

date: Modified Julian Date represented using 2 bytes as defined in EN 300 468 [1], annex C. 

time: Time of the day represented using 1 1 bits, expressed as the number of elapsed minutes since midnight. 
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9.4.3.6 



dvbDurationCodec 



9.4.3.6.1 



Rationale and encoding process (informative) 



The XML Schema primitive simple type duration is used widely within the TVA metadata Schema, and so a specific 
codec has been designed to represent date time elements or attributes. 

The XML Schema primitive simple type duration is used by the following TV-Anytime types: ScheduleEventType, and 
OnDemandProgramType. 

In order to efficiently encode duration elements or attributes, it is recommended to represent the duration information 
are represented using 11 bits, with an accuracy of 1 minute. 

9.4.3.6.2 Decoding 

The format of the dvbDurationCodec is defined by table 67. 

Table 67: dvbDurationCodec 



Name 


No. of bits 


Identifier 


dvbDurationCodec { ) { 






encoding flag 


1 


bslbf 


if {encoding flag ==0) { 






dvbStringCodec { ) 

} 

if {encoding flag == 1) { 










minutes 
} 
} 


11 


uimsbf 



encoding_flag: If the encoding_flag is set to 0, the duration is encoded as a string as specified by XML Schema 
part 2 [16], clause 3.2.6. If the encoding_flag is set to 1, the duration is encoded as a number of minutes. 

dvbStringCodecQ: For the definition of the dvbStringCodec see clause 9.4.3.3. 

minutes: the duration is encoded as a number of minutes and represented using 1 1 bits. 



9.4.3.7 



dvbControlledTermCodec 



9.4.3.7.1 



Usage 



The dvbControlledTermCodec codec is used by default for encoding elements and attributes of type 
termReferenceType . 



9.4.3.7.2 



Rationale and encoding process (informative) 



Default classification schemes have been developed by TV-Anytime to provide a universally applicable default set of 
classification terms. 

The following dvbControlledTermCodec shall be used by default for encoding the fixed values defined by 
TV-Anytime. It encodes references to the classification scheme and a controlled term from that scheme. 

When using the dvbControlledTermCodec for fixed terms defined by TV-Anytime classification schemes, it is 
recommended that elements of type ControlledTermType should not include Name or Definition child elements. 
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9.4.3.7.3 Decoding 

The format of the ControUedTermCodec is defined by table 68. 

Table 68: ControlledTermCodec 



Name 


No. of bits 


Identifier 


dvbControlledTermCodec {) { 






encoding_f lag 


1 


bslbf 


if {encoding flag ==0) { 






dvbStringCodec { ) 

} 

if {encoding flag == 1) { 










grouping_f lag 


1 


bslbf 


if {grouping flag ==0) { 






Classif icationSchemelD 


7 


uimsbf 


} else { 






Classif icationSchemeGroupID 


4+ 


vluimsbf4 


Classif icationSchemelndex 

} 
termID 

} 
} 


8+ 


vluimsbf8 


8+ 


vluimsbf8 



encoding_flag: If the encoding_flag is set to 0, the term reference is encoded as a string. If the encoding_fIag is set to 0, 
the term reference as a pair of classification schema identifier and term identifier. 

dvbStringCodecQ: For the definition of the dvbStringCodec see clause 9.4.3.3. 

grouping_flag: if the grouping_flag is set to 0, the Classification Scheme is encoded by a ClassificationSchemelD. If 
the grouping_flag is set to 1, the Classification Scheme is encoded by a ClassificationSchemeGroupID and a 
ClassificationSchemelndex. 

ClassificationSchemelD: An identifier for the classification schemes defined in TV-Anytime 2004 [25]. This field 
shall be encoded according to table 69. 

ClassificationSchemeGroupID: An identifier for the group of classification schemes, defined in table 70. 

ClassificationSchemelndex: An identifier for a classification scheme encoded according to the group it belongs to as 
specified in table 70. When the ClassificationSchemeGroupID is set to 0x0, the ClassificationSchemelndex corresponds 
to an index within the list of classification schemes given as parameter to the dvbControlledTermCodec in the 
decoderlnit (starting from 0x0). The syntax of the initialization procedure for the dvbControlledTermCodec is defined 
in table 75. 
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Table 69: ClassificationSchemelD 



Value 


Classification scheme URI 


0x00 


reserved 


0x01 


urn:tva:metadata:cs:ActionTypeCS:2004 


0x02 


urn:tva:metadata:cs:AtmosphereCS:2004 


0x03 


urn:tva:metadata:cs:ContentAlertCS:2004 


0x04 


urn:tva:metadata:cs:ContentCommercialCS:2004 


0x05 


urn:tva:metadata:cs:ContentCS:2004 


0x06 


urn:tva:metadata:cs:FormatCS:2004 


0x07 


urn:tva:metadata:cs:HowRelatedCS:2004 


0x08 


urn:tva:metadata:cs:lntendedAudienceCS:2004 


0x09 


urn:tva:metadata:cs:lntentionCS:2004 


OxOA 


urn:tva:metadata:cs:LanguageCS:2004 


0x0 B 


urn:tva:metadata:cs:MediaTypeCS:2004 


OxOC 


urn:tva:metadata:cs:OriginationCS:2004 


0x0 D 


urn:mpeg:mpeg7:cs:RoleCS:2001 


0x0 E 


urn:tva:metadata:cs:TVARoleCS:2004 


0x0 F 


urn:tva:metadata:cs:AudioPurposeCS:2004 


0x10 


urn:tva:metadata:cs:PurchaseTypeCS:2004 


0x11 


urn:tva:metadata:cs:UnitTypeCS:2004 


0x1 2 to 0x70 


DVB Reserved 


0x71 to 0x7F 


User Private 



Table 70: ClassificationSchemeGroupID 



Value 


Classification scheme group 


0x0 


Group of classification schemes defined in tlie decoderlnit 


0x1 


User Private 


0x2 


Group of classification schemes from TV-Anytime 2005 [26] (table 71) 


0x3 


Group of classification schemes from DVB-IPDC [28] (table 72) 


0x4 


Group of classification schemes from DVB-AVC (table 73) 


0x5 


Group of classification schemes from TV-Anytime 2007 [4] (table 74) 


0x6.... 


DVB reserved 



Table 71 : ClassificationSchemelndexes for TV-Anytime 2005 



Value 


Classification scheme URI 


0x00 


reserved 


0x01 


urn:tva:metadata:cs:AtmosphereCS:2005 


0x02 


urn:tva:metadata:cs:ContentAlertCS:2005 


0x03 


urn:tva:metadata:cs:ContentCommercialCS:2005 


0x04 


urn:tva:metadata:cs:ContentCS:2005 


0x05 


urn:tva:metadata:cs:FormatCS:2005 


0x06 


urn:tva:metadata:cs:HowRelatedCS:2005 


0x07 


urn:tva:metadata:cs:lntendedAudienceCS:2005 


0x08 


urn:tva:metadata:cs:lntentionCS:2005 


0x09 


urn:tva:metadata:cs:MediaType:2005 


OxOA 


urn:tva:metadata:cs:OriginationCS:2005 


0x0 B 


urn:tva:metadata:cs:TVARoleCS:2005 


OxOC... 


DVB reserved 



Table 72: ClassificationSchemelndexes for DVB-IPDC 



Value 


Classification scheme URI 


0x00 


reserved 


0x01 


urn:dvb:ipdc:esg:cs:ServiceTypeCS:2005 


0x02 


urn:dvb:ipdc:esg:cs:ZappingSupportCS:2005 


0x03... 


DVB reserved 
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Table 73: ClassificationSchemelndexes for DVB-AVC 



Value 


Classification scheme URI 


0x00 


reserved 


0x01 


urn:dvb:metadata:cs:AudioCodecCS:2007[29] 


0x02 


urn:dvb:metadata:cs:VideoCodecCS:2007 [30] 


0x03... 


DVB reserved 



Table 74: ClassificationSchemelndexes for TV-Anytime 2007 



Value 


Classification scheme URI 


0x00 


reserved 


0x01 


urn:tva:metadata:cs:AudioPurposeCS:2007 


0x02 


urn:tva:metadata:cs:CaptionCodingFormatCS:2007 


0x03 


urn:tva:metadata:cs:ContentCS:2007 


0x04 


urn:tva:metadata:cs:DerivationReasonTypeCS:2007 


0x05 


urn:tva:metadata:cs:FormatCS:2007 


0x06 


urn:tva:metadata:cs:HowRelatedCS:2007 


0x07 


urn:tva:metadata:cs:UnitTypeCS:2007 


0x08... 


DVB reserved 



Table 75: Syntax of dvbControlledTermCodecParameters 



Syntax 


No. of bits 


Identifier 


dvbControlledTermCodecParameters {) { 
nbClassif icationSchemes 

for {j=0; j <nbClassif icationSchemes; j++) { 
Classif icationSchemeURI Length [ j ] 
Classif icationSchemeURI [j] 
} 
} 


8+ 

8+ 
8*ClassificationSchemeURI_LengthO] 


vluimsbfS 

vluimsbfS 
bslbf 



termID: The rank of the element in the classification Scheme. This termID is coded as a vluimsbfS in order to support 
extension to the classification schemes. The rank of the first term according to document order shall be zero. 

NOTE: The rank of an element should not be calculated before processing all import statements and ordering all 
imported elements. 



9.4.4 Forward compatibility 



9.4.4.1 



Use of forward compatible mode 



A decoder shall be able to decode all information related to the schema identified by the urn 'urn:tva:metadata:2004' and 
shall be able to skip information related to any schema extensions. 

If the schema 'urn;tva;metadata:2004' is extended, instance documents using those extensions shall be encoded in a 
forward compatible manner. 



9.4.4.2 



Overview (informative) 



As defined in ISO/IEC 15938-1 [10], with some constraints, interoperability is provided between different versions of 
ISO/IEC 15938 [i.l] schema definitions, without the full knowledge of all schema versions being required. 

It is assumed that the updated version of a schema imports the previous version of that schema. Forward compatibility 
allows a decoder only aware of a previous version of a schema to partially decode a description conformant to an 
updated version of that schema. 
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Forward compatibility is ensured by a specific syntax defined in ISO/IEC 15938-1 [10], clauses 7 and 8. Its main 
principle is to use the namespace of the schema, i.e. the Schema URI, as a unique version identifier. The binary format 
allows one to keep parts of a description related to different schema in separate chunks of the binary description stream, 
so that parts related to unknown schema may be skipped by the decoder. 

In order for this approach to work, an updated schema should not be defined using the ISO/IEC 15938-2 [22] "redefine" 
construct but should be defined in a new namespace. The Decoder Initialization identifies schema versions with which 
compatibility is preserved by listing their Schema URIs. A decoder that knows at least one of the Schema URIs will be 
able to decode at least part of the binary description stream. 

In case an updated version of the schema is used, an element is coded in several version-consistent bitstream chunks i.e. 
ElementContentChunks. All elements in an ElementContentChunk are decoded using a single schema. A schema 
identifier is present before each ElementContentChunk. These identifiers are generated on the basis of URIs conveyed 
in the Decoderlnit (see ISO/IEC 15938-1 [10], clause 7.2). A Length is present when the element is coded in several 
ElementContentChunks, allowing the decoder to skip ElementContentChunks related to unknown schema. 

NOTE: The decoder keeps track of a SchemaModeStatus. It is used to improve coding efficiency. The decoder 
can "freeze" the schema needed to decode the description. In this case no overhead is induced by the 
multiple-version element coding for the elements contained in the element being decoded, i.e. the entire 
sub-tree. 



9.4.4.3 



Multiple version encoding of an element (informative) 



Each XML element is associated to a type which defines its content model. Derived types are defined by restriction or 
extension of existing types. When managing different versions of a schema, a version 2 type might extend a version 1 
type as shown in figure 14. In this case, a multiple-version coding can be used to provide a forward compatible coding 
of this element. For example, the type T2.6 can be coded in two ElementContentChunks. The first 
ElementContentChunk could encode those parts of T2.6 which were derived from T1.4 (see figure 15). Encoding would 
be done exactly as if it were type T1.4. The second ElementContentChunk then encodes the difference between types 
T1.4 and T2.6. A "Schema-1 -decoder" will be able to decode the first part of the element content and skip the second 
part using the Length information. Figure 16 shows the same element encoded in a non forward compatible way. 



Type of the element 
to be decoded 




Schema 1 



Schema 2 



Figure 14: Example of a type hierarchy defined across versions 



Length 



SI 


T1.4 





S2 


T2.6 





Figure 15: Example of a forward compatible encoding 



Length 



S2 


T2.6 





Figure 16: Example of a non forward compatible encoding 
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9.5 TV-Anytime structures 



9.5.1 Profiled index structures 



9.5.1.1 



Introduction 



TS 102 822-3-2 [5], clause 4.8.5 defines a means to index metadata delivered on a uni-directional network. If a 
metadata service is delivered indexing may be included that conforms to TS 102 822-3-2 [5]. The present document 
defines a number of profiled indices; if a metadata service carries an index that is of the same type as one of the profiled 
indices defined in the present document, that is with the same fragment XPath and field XPath(s), then that index must 
conform to the profiled format defined herein. A metadata service may contain indices of other types not profiled in the 
present document, in which case those indices must conform to TS 102 822-3-2 [5]. 

The profiled indices are defined in the following way: structures are expressed in an informative, simplified form that 
removes options not used; normative values and options are defined. The structure definitions and field semantics are 
normatively defined in TS 102 822-3-2 [5], the profiled indices conform to TS 102 822-3-2 [5]. 

See clause 9.4.2.2 for creating indices for extended schemas. 

9.5.1 .2 Field identifier values 

Table 76 defines the permitted values of the field identifier field in the index list structure. 

Table 76: Allowed values of field identifier field 



Value 


Equivalent field XPath expression 


0x0000 


"@tva:groupld" 


0x0001 


"tva:BasicDescription/tva:Title.text()" 


0x0002 


"@tva:programid" 


0x0003 


"@tva:end" 


0x0004 


"@tva:ServicelDRef" 


0x0005 


"tva:ScheduleEvent/tva:lnstanceDescription/tva:Title.text()" 


0x0006 to 0x7FFF 


DVB reserved 


0x7FFF to OxFFFE 


user private 


OxFFFF 


Field Xpath expression is carried as a string 



9.5.1.3 



Index List 



Table 77 is informative. It illustrates how the ListEntry profiled index structures defined in the present document fit into 
the index list structure, which is defined normatively in TS 102 822-3-2 [5]. 

If a receiver does not recognize the index definition for any entry in the index_list that entry shall be ignored. 
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Table 77: Index list 



Syntax 


No. of 
bits 


Identifier 


Value 


Comment 


index_list() { 










for (i=0; i<N; i++) { 










Either Groupinf oCridlndexListEntry ( ) 








entries for profiled indices 


OR Groupinf oTitlelndexListEntry ( ) 










OR Programinf OCridlndexListEntry ( ) 










OR Programinf OTitlelndexListEntry ( ) 










OR ScheduleTimeServicelndexListEntry ( ) 










OR ScheduleTitlelndexListEntry 










OR { 








generic index entry 


index descriptor length 


8 


uimsbf 


+ 
(see note 1 ) 




fragment type 


16 


uimsbf 


+ 




if (fragment type == OxFFFF) { 










fragment xpath ptr 


16 






if fragment_type==OxFFFF this 
is ref. (see note 2) to XPath 
string 


} 










num fields 


8 


uimsbf 


+ 




for ( i=0; i<num fields; i++) { 










field identifier 


16 


uimsbf 


+ 


OxFFFF indicates use of W3C 
Xpath expression for field. 


if (field_identifier == OxFFFF) { 










field xpath ptr 


16 


uimsbf 


* 
(see note 3) 


if field_identifier==OxFFFF this 
is ref. to XPath string 


} 










field encoding 


16 


uimsbf 


+ 




} 










container id 


16 


uimsbf 


+ 




index identifier 


8 


uimsbf 


+ 




} 










} 










} 










NOTE 1 : "+" indicates tliat tlie value is assigned (e.g. an identifier value). 

NOTE 2: References to strings are all offsets from the start of the string_repository carried in the same container. 

NOTE 3: " * " indicates that the value is calculated (e.g. a length or an offset value). 



9.5.1 .4 Grouplnformation index by GRID 

9.5.1.4.1 Index definition 

An index of Grouplnformation by GRID is defined by the XPath values in table 78. 

Table 78: XPath values for Grouplnformation index by CRID 





Value 


fragment Xpath 


/tva:TVAIVIain/tva:ProgramDescription/tva:Grouplnformation 
Table/tva:Grouplnformation 


field Xpath 


@tva:groupld 



The following structures define how an index of Grouplnformation by GRID shall be constructed if present. These 
structures are compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 
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9.5.1.4.2 Index list entry 

Table 79 defines the index list entry that must be included in the index list structure if an index of this type is delivered. 
Table 79: Index list entry for Grouplnformation index by CRID 



Syntax 


No. of bits 


Value 


Comments 


Groupinf oCridlndexListEntry ( ) { 








index descriptor length 


8 


OxOC 




fragment type 


16 


0x0002 


indicates Grouplnformation 
fragment. 


num fields 


8 


0x01 


single key index. 


field identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for field. 


field xpath ptr 


16 


* 


ref. to string "@tva:groupld". 


field encoding 


16 


0x0000 


indicates no encoding for field 
entries in GrouplnfoCridlndex 
or GrouplnfoCridSublndex 
structures. 


container id 


16 


+ 


the ID of the container carrying 
the GrouplnfoCridlndex 
structure. 


index identifier 


8 


+ 


the structurejd of the 
GrouplnfoCridlndex structure. 


} 









9.5.1.4.3 Index structure 

Table 80 defines the profile of index structure that must be used if an index of this type is delivered. 
Table 80: Index structure for Grouplnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


Groupinf oCridlndex { ) { 








Overlapping subindices 


1 


'C 


no overlapped indexing. 


Single layer sub index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for {i=0; i<num sub indicies; i++) { 








high field value 


16 


* 


ref. to CRID string. 


Grouplnfo sub index container 


16 


+ 


the ID of the container carrying the 
GrouplnfoCridSublndex structure. 


Grouplnfo sub index identifier 


8 


+ 


the structurejd of the 
GrouplnfoCridSublndex structure. 


} 








} 
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9.5.1 .4.4 Sub index structure 

Table 81 defines the profile of multi_field_sub_index structure that must be used if an index of this type is delivered. 
Table 81 : Sub index structure for Grouplnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


GroupInfoCridSublndexO { 








{ 






multi field header. 


leaf_field 


1 


'1' 


Only one index layer so this is the leaf field. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111 




} 








for (j=0; j<num entries; j++) { 






repeat for each CRID indexed. 


field value 


16 


* 


ref. to Grouplnformation CRID string. 


{ 






inline fragment locator structure referencing 
remote (see note) fragments. 


target container 


16 


+ 


container carrying Grouplnfo fragment. 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 








NOTE: "Remote fragments" are fragments not in the same container as the sub index structure. This format of 
fragment locator is the more flexible, but is not optimized for when data fragments are delivered in the 
same containers as the index structures. 



9.5.1 .5 Grouplnformation index by title 

9.5.1.5.1 Index definition 

An index of Grouplnformation by title is defined by the XPath values in table 82. 

Table 82: XPath values for Grouplnformation index by title 





Value 


fragment Xpath 


/tva:TVAMain/tva:ProgramDescription/tva:GrouplnformationT 
able/tva:Grouplnformation 


field Xpath 


tva:BasicDescription/tva:Title.text() 



The following structures define how an index of Grouplnformation by title shall be constructed if present. These 
structures are compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 
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9.5.1.5.2 Index list entry 

Table 83 defines the index list entry that must be included in the index list structure if an index of this type is delivered. 
Table 83: Index List entry for Grouplnformation index by title 



Syntax 


No. of bits 


Value 


Description 


Groupinf oCridlndexListEntry ( ) { 








index descriptor length 


8 


OxOC 




fragment type 


16 


0x0002 


indicates Grouplnformation fragments. 


num fields 


8 


0x01 


single key index. 


field identifier 


16 


OxFFFF 


indicates use of W3C Xpath expression for 
field. 


field xpath ptr 


16 


* 


ref. to string 
"tva:BasicDescription/tva:TJtle.text()". 


field encoding 


16 


0x0000 


indicates no encoding for field entries in 
GrouplnfoTitlelndex or 
GrouplnfoTitleSublndex structures. 


container id 


16 


+ 


tlie ID of the container carrying the 
GrouplnfoTitlelndex index structure. 


index identifier 


8 


+ 


the structurejd of the GrouplnfoTitlelndex 
index structure. 


} 









9.5.1 .5.3 Index structure 

Table 84 defines the profile of index structure that must be used if an index of this type is delivered. 
Table 84: Index structure for Grouplnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


Groupinf oCridlndex { ) { 








Overlapping subindices 


1 


'0' 


no overlapped indexing. 


Single layer sub index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for {i=0; i<num sub indicies; i++) { 








high field value 


16 


* 


ref. to title string. 


Grouplnfo sub index container 


16 


+ 


the ID of the container carrying the 
GrouplnfoTitleSublndex structure. 


Grouplnfo sub index identifier 


8 


+ 


the structurejd of the 
GrouplnfoTitleSublndex structure. 


} 








} 
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9.5.1 .5.4 Sub index structure 

Table 85 defines the profile of multi_field_sub_index structure that must be used if an index of this type is delivered. 
Table 85: Sub index structure for Grouplnformation index by title 



Syntax 


No. of bits 


Value 


Description 


GroupInfoTitleSublndexO { 








{ 






multi field header. 


leaf_field 


1 


'1' 


Only one index layer so this is 
the leaf field. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111 




} 








for (j=0; j<num entries ; j++) { 






repeat for each title indexed. 


field value 


16 




ref. to Grouplnformation title 
string. 


{ 






inline fragment locator structure 
referencing remote fragments. 


target container 


16 


+ 


container carrying 
Grouplnformation fragment. 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 









9.5.1 .6 Program Information index by GRID 

9.5.1.6.1 Index definition 

An index of Programlnformation by CRID is defined by the XPath values in table 86. 

Table 86: XPath values for Programlnformation index by CRID 





Value 


fragment Xpath 


/tva:TVAMain/tva:ProgramDescription/tva:Programlnformation 
Table/tva:Programlnformation 


field Xpath 


@tva:programid 



The following structures define how an index of Programlnformation by CRID shall be constructed if present. These 
structures are compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 
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9.5.1.6.2 Index list entry 

Table 87 defines the index list entry that must be included in the index list structure if an index of this type is delivered. 
Table 87: Index List entry for Programlnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridlndexListEntry ( ) { 








index descriptor length 


8 


OxOC 




fragment type 


16 


0x0001 


indicates Programlnformation 
fragment. 


num fields 


8 


0x01 


single key index. 


field identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for field. 


field xpath ptr 


16 


* 


ref. to string "@tva:programld". 


field encoding 


16 


0x0000 


indicates no encoding for field 
entries in 

ProgramlnfoCridlndex or 
ProgramlnfoCridSublndex 
structures. 


container id 


16 


+ 


the ID of the container carrying 
the ProgramlnfoCridlndex 
structure. 


index identifier 


8 


+ 


the structurejd of the 
ProgramlnfoCridlndex 
structure. 


} 









9.5.1.6.3 Index structure 

Table 88 defines the profile of index structure that must be used if an index of this type is delivered. 
Table 88: Index structure for Programlnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridlndex ( ) { 








Overlapping subindices 


1 


'0' 


no overlapped indexing. 


Single layer sub index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for (i=0; i<num sub indicies; i++) { 








high field value 


16 


* 


ref. to CRID string. 


Programlnfo sub index container 


16 


+ 


the ID of the container carrying 
the ProgramlnfoCridSublndex 
structure. 


Programinf o sub index identifier 


8 


+ 


the structurejd of the 

ProgramlnfoCridSublndex 

structure. 


} 








} 
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9.5.1 .6.4 Sub index structure 

Table 89 defines the profile of multi_field_sub_index structure that must be used if an index of this type is delivered. 
Table 89: Sub index structure for Programlnformation index by CRID 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridSublndex ( ) { 








{ 






multi field header. 


leaf_field 


1 


'1' 


Only one index layer so this is 
the leaf field. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111 




} 








for (j=0; j<num entries ; j++) { 






repeat for each CRID indexed. 


field value 


16 




ref. to Programlnformation CRID 
string. 


{ 






inline fragment locator structure 
referencing remote fragments. 


target container 


16 


+ 


container carrying Programlnfo 
fragment. 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 









9.5.1 .7 Programlnformation index by title 

9.5.1.7.1 Index definition 

An index of Programlnformation by title is defined by the XPath values in table 90. 

Table 90: XPath values for Grouplnformation index by title 





Value 


fragment Xpath 


/tva:TVAMain/tva:ProgramDescription/tva:Programlnformati 
onTable/tva:Programlnformation 


field Xpath 


tva:BasicDescription/tva:Title.text() 



The following structures define how an index of Programlnformation by title shall be constructed if present. These 
structures are compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 
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9.5.1.7.2 Index list entry 

Table 91 defines the index list entry that must be included in the index list structure if an index of this type is delivered. 
Table 91 : Index List entry for Programlnformation index by title 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridlndexListEntry ( ) { 








index descriptor length 


8 


OxOC 




fragment type 


16 


0x0001 


indicates Programlnformation 
fragments. 


num fields 


8 


0x01 


single key index. 


field identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for field. 


field xpath ptr 


16 




ref. to string 

"tva:BasicDescription/tva:Title.te 

xtO". 


field encoding 


16 


0x0000 


indicates no encoding for field 
entries in ProgramlnfoTitlelndex 
or ProgramlnfoTitleSublndex 
structures. 


container id 


16 


+ 


the ID of the container carrying 
the ProgramlnfoTitlelndex 
index structure. 


index identifier 


8 


+ 


the structurejd of the 
ProgramlnfoTitlelndex Jndex 
structure. 


} 









9.5.1.7.3 Index structure 

Table 92 defines the profile of index structure that must be used if an index of this type is delivered. 
Table 92: Index structure for Programlnformation index by title 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridlndex ( ) { 








Overlapping subindices 


1 


'0' 


no overlapped indexing. 


Single layer sub index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for (i=0; i<num sub indicies; i++) { 








high field value 


16 


* 


ref. to title string. 


Programlnfo sub index container 


16 


+ 


the ID of the container carrying 
the ProgramlnfoTitleSublndex 
structure. 


Programlnfo sub index identifier 


8 


+ 


the structurejd of the 

ProgramlnfoTitleSublndex 

structure. 


} 








} 
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9.5.1 .7.4 Sub index structure 

Table 93 defines the profile of multi_field_sub_index structure that must be used if an index of this type is delivered. 
Table 93: Sub index structure for Programlnformation index by title 



Syntax 


No. of bits 


Value 


Description 


Programinf oCridSublndex ( ) { 








{ 






multi field header. 


leaf_field 


1 


'1' 


Only one index layer so this is 
the leaf field. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111' 




} 








for (j=0; j<num_entries; j++) { 






repeat for each title indexed. 


field value 


16 


* 


ref. to Programlnformation title 
string. 


{ 






inline fragment locator structure 
referencing remote fragments. 


target container 


16 


+ 


container carrying 
Programlnformation fragment 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 









9.5.1 .8 Schedule index by time and DVB service 

9.5.1.8.1 Index definition 

An index of Schedule by time and DVB service is defined by the XPath values in table 94. 

Table 94: XPath values for Schedule index by time and DVB service 





Value 


fragment Xpath 


/tva:TVAMain/tva:ProgramDescription/tva:ProgramLocation 
Table/tva:Schedule 


first field Xpath 


@tva:end 


second field Xpath 


@tva:ServicelDRef 



The following structures define how an index of Schedule by DVB service and time shall be constructed if present. 
These structures are compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 

The index of Schedule by time and DVB service is a two-layer index, indexing first by the value of the end time of the 
period covered by a Schedule fragment and second by the value of serviceldRef. 
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9.5.1.8.2 Index list entry 

Table 95 defines the index list entry that must be included in the index list structure if an index of this type is delivered. 
Table 95: Index List entry for Schedule index by time and DVB service 



Syntax 


No. of bits 


Value 


Description 


ScheduleTimeServicelndexListEntry ( ) { 








index descriptor length 


8 


0x12 




fragment type 


16 


0x0005 


indicates Schedule fragment. 


num fields 


8 


0x02 


two key index. 


fieldl identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for first l<ey field. 


fieldl xpath ptr 


16 


* 


ref. to string "@tva:end". 


fieldl encoding 


16 


0x0000 


indicates no encoding for first key 
field entries in 

ScheduleTimeServicelndex or 
ScheduleTimeServiceSublndex 
structures. 


field2 identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for second key field. 


field2 xpath ptr 


16 


* 


ref. to string "@tva:serviceldRef". 


field2 encoding 


16 


0x0000 


indicates no encoding for second 
key field entries in 
ScheduleTimeServicelndex or 
ScheduleTimeServiceSublndex 
structures. 


container id 


16 


+ 


the ID of the container carrying the 

ScheduleTimeServicelndex 

structure. 


index identifier 


8 


+ 


the structurejd of the 

ScheduleTimeServicelndex 

structure. 


} 









9.5.1.8.3 Index structure 

Table 96 defines the profile of index structure that must be used if an index of this type is delivered. 
Table 96: Index structure for Schedule index by time and DVB service 



Syntax 


No. of bits 


Value 


Description 


ScheduleTimeServicelndex ( ) { 








Overlapping subindices 


1 


'0' 


no overlapped indexing. 


Single layer_sub_index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for (i=0; i<num sub indices; i++) { 








high field valuel 


16 


* 


ref. to date string. 


high field value2 


16 


* 


ref. to serviceldRef string. 


Schedule sub index container 


16 


+ 


the ID of the container carrying 
the ScheduleCridSublndex 
structure. 


Schedule sub index identifier 


8 


+ 


the structurejd of the 

ScheduleCridSublndex 

structure. 


} 








} 
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9.5.1.8.4 



Sub index structure layer 1 



Table 97 defines the profile of multi_field_sub_index structure that must be used for the first layer of indexing if an 
index of this type is delivered. 

The first layer sub index structure for a schedule index by time and DVB service lists all values of the "end" attribute 
for entries in the current container. A first layer sub index structure must be carried in the same container as the 
corresponding second layer sub index structure. Entries in this first layer sub index must be ordered by incrementing 
value of time. 

Table 97: First layer sub index structure for Schedule index by time and DVB service 



Syntax 


No. of bits 


Value 


Description 


ScheduleCridSublndexl { 








{ 






multi field header. 


leaf_field 


1 


'0' 


this is not the last sub index 
layer. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111' 




} 








child sub index ref 


8 


+ 


The structurejd of the 
associate 2"'' layer sub index 
structure. 


for (j=0; j<num entries ; j++) { 






repeat for each DVB service 
indexed in this container. 


field value 


16 


* 


ref. to end time string. 


range end offset 


16 


+ 


container carrying Schedule 
fragment. 


} 








} 









9.5.1.8.5 



Sub index structure layer 2 



Table 98 defines the profile of multi_field_sub_index structure that must be used for the second layer of indexing if an 
index of this type is delivered. 

The second layer sub index structure for a schedule index by time and DVB service lists references to fragments, giving 
the value of ServiceldRef of referenced fragments. Every first layer sub index structure must be carried in the same 
container as its corresponding second layer sub index structure. Entries in this second layer sub index relating to the 
same first layer sub index entry must be ordered by ascending lexicographical value. 

Table 98: Second layer sub index structure for Schedule index by time and DVB service 



Syntax 


No. of bits 


Value 


Description 


ScheduleCridSubIndex2 {) { 








{ 






multi field header. 


leaf_field 


1 


'1' 


this is the last sub index layer. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111' 




} 








for {j=0; j<num entries; j ++) { 






repeat for each schedule fragment 
indexed in this container. 


field value 


16 


* 


ref. to Schedule service string. 


{ 






inline fragment locator structure 
referencing remote fragments. 


target container 


16 


+ 


container carrying Schedule fragment. 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 
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9.5.1.9 



Schedule index by title 



9.5.1.9.1 Index definition 

An index of Schedule by title is defined by the XPath values in table 99. 

Table 99: XPath values for Schedule index by title 





Value 


fragment Xpath 


/tva:TVAMain/tva:ProgramDescription/tva:ProgramLocation 
Table/tva:Schedule 


field Xpath 


tva:ScheduleEvent/tva:lnstanceDescription/tva:Title.text{) 



The following structures define how an index of Schedule by title shall be constructed if present. These structures are 
compatible with the index and multi_field_sub_index structures defined by TS 102 822-3-2 [5]. 

Note that one Schedule fragment may contain more than one ScheduleEvent element, therefore each Schedule fragment 
will be referenced once for each ScheduleEvent it contains. 



9.5.1.9.2 



Index list entry 



Table 100 defines the index list entry that must be included in the index list structure if an index of this type is 
delivered. 

Table 100: Index List entry for Schedule index by Title 



Syntax 


No. of bits 


Value 


Description 


ScheduleTitlelndexListEntry { 








index descriptor length 


8 


OxOC 




fragment type 


16 


0x0002 


indicates Schedule fragments. 


num fields 


8 


0x01 


single key index. 


field identifier 


16 


OxFFFF 


indicates use of W3C Xpath 
expression for field. 


field xpath ptr 


16 




ret. to string 

"tva:ScheduleEvent/tva:lnstance 

Description/tva:Title.text()". 


field encoding 


16 


0x0000 


indicates no encoding for field 
entries in ScheduleTitlelndex or 
ScheduleTitleSublndex 
structures. 


container id 


16 


+ 


the ID of the container carrying 
the ScheduleTitlelndex Jndex 
structure. 


index identifier 


8 


+ 


the structurejd of the 
ScheduleTitlelndex Jndex 
structure. 


} 
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9.5.1.9.3 Index structure 

Table 101 defines the profile of index structure that must be used if an index of this type is delivered. 

Table 101 : Index structure for Schedule index by title 



Syntax 


No. Of 
bits 


Value 


Description 


ScheduleCridlndexO { 








Overlapping subindices 


1 


'0' 


no overlapped indexing. 


Single layer sub index 


1 


'0' 


single layer only. 


Reserved 


6 


'111111' 




fragment locator format 


8 


0x01 


remote fragment locators. 


for (i=0; i<num sub indicies; i++) { 








high field value 


16 


* 


ref. to title string. 


Schedule sub index container 


16 


+ 


the ID of the container carrying the 
ScheduleTitleSublndex structure. 


Schedule sub index identifier 


8 


+ 


the structurejd of the 
ScheduleTitleSublndex structure. 


} 








} 









9.5.1 .9.4 Sub index structure 

Table 102 defines the profile of multi_field_sub_index structure that must be used if an index of this type is delivered. 
Table 102: Sub index structure for Schedule index by title 



Syntax 


No. Of 
bits 


Value 


Description 


ScheduleCridSublndex { ) { 








{ 






multi field header. 


leaf_field 


1 


'1' 


Only one index layer so this is 
the leaf field. 


multiple locators 


1 


'0' 


fragment locators are in-line. 


Reserved 


6 


'111111' 




} 








for {j=0; j<num entries;j++) { 






repeat for each title indexed. 


field value 


16 


* 


ref. to Schedule title string. 


{ 






inline fragment locator structure 
referencing remote fragments. 


target container 


16 


+ 


container carrying Schedule 
fragment. 


target fragment 


24 


+ 


unique fragment ID. 


} 








} 








} 









9.5.2 Additional structures 



9.5.2.1 



Structure types 



TS 102 822-3-2 [5], clause 4 defines a number of structure types for the purpose of carriage of TV-Anytime 
information. These structures shall be delivered by container, each structure having a structure_type and structurejd 
used to reference it from the container_header (see clause 4.5.2.1 of that specification). 

Structure types extending TS 102 822-3-2 [5], clause 4 are defined in the present document. The structure type and field 
of the container_header (see TS 102 822-3-2 [5] clause 4.5.2. 1) shall be encoded as defined in table 103 if such a 
structure is included in a container. 
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Table 103: Structure type 



Value 


Meaning 


0x00 to 0x7F 


TVA structures 


0x80 


type list 


0x81 


namespace map 


0x81 to OxAF 


DVB reserved 


OxBO to OxFF 


private use 



9.5.2.2 



Type list 



The type list structure is an extension to the TV-Anytime structures for carriage of metadata in unidirectional 
environments (see TS 102 822-3-2 [5], clause 4.5), its purpose is to define which containers carry certain types of 
metadata. 

At most one type list structure may be carried in a metadata service. If present it shall be carried in the container with 
container ID equal to 0x0000. When the type list structure is present in a container, the structure_type and structure_id 
fields in the container_header (see TS 102 822-3-2 [5], clause 4.5.2.1) shall be set to 0x80 and 0x00, respectively. 

This structure may contain entries for any number of types, but for each type there must be at most one entry. 
Additionally, for each entry, all containers in the current metadata service should be listed that carry fragments of the 
relevant type. 



Table 104 defines the type list structure. 



Table 104: Type list structure 



Syntax 


No. of bits 


Identifier 


type list structure {) { 






num_types; 


16 


uimsbf 


for {i=0; i<num types; i++) { 






reserved 


4 


uimsbf 


type description length 


12 


uimsbf 


fragment type 


16 


uimsbf 


if {fragment_type == OxFFFF) { 






fragment xpath ptr 

} 

num containers 


16 


uimsbf 


8 


uimsbf 


for {j=0; j< num containers; j++) { 






container id 
} 
} 
} 


16 


uimsbf 



num_types: This field shall be set to the number of fragment types listed in this structure. 

reserved: This field shall be set to '1 111'. 

type_description_length: This field shall be set to the number of bytes immediately following it in this fragment type 
entry. 

fragment_type: This field identifies the type of fragment this entry pertains to. It shall be encoded according to the 
fragment_type field of the index list structure defined in clause 4.8.5.3 of TS 102 822-3-2 [5]. 

fragment_xpath_ptr: If the fragment_type is set to OxFFFF then this field shall provide a reference to the XPath string 
that describes the fragment type for this entry. This reference shall be set to the offset, in bytes, from the start of the 
string repository in the current container to the first character of the fragment type XPath string. 

nuin_containers: This field shall be set to the number of container_ids immediately following. 

container_id: This field shall be set to the container_id of a container that carries at least one fragment that matches the 
fragment type of this entry. 
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9.5.2.3 



XPath namespace map 



The XPath namespace map structure is an extension to the TV Anytime structures for carriage of metadata in 
unidirectional environments (see TS 102 822-3-2 [5], clause 4). Its purpose is to define namespace prefixes used in 
fragment type XPath and field XPath fields in an index list structure (see TS 102 822-3-2 [5], clause 4.8.5.3). 

At most one XPath namespace map structure may be carried in a metadata service. If present it shall be carried in the 
container with container ID equal to 0x0000. When the XPath namespace map structure is present in a container, the 
structure_type and structure_id fields in the container_header (see TS 102 822-3-2 [5], clause 4.5.2.1) shall be set to 
0x81 and 0x00, respectively. 

If present, the XPath namespace map structure defines namespace prefixes used within the index list structure carried in 
the same container. These namespace prefixes are in addition to those defined in TS 102 822-3-2 [5], clause 4.8.5.3. 
This structure shall only be used in metadata services that deliver metadata types defined by a schema that extends the 
TV- Anytime metadata schema (see TS 102 822-3-1 [4]). Where present this structure may be ignored by receivers that 
do not understand the extended elements of the schema. 

Table 105 defines the XPath namespace map structure. 

Table 105: Namespace map structure 



Syntax 


No. of bits 


Identifier 


namespace_map_structure ( ) { 






num_pref ixes ; 


8 


uimsbf 


for (i=0; i<num prefixes; i++) { 






prefix length 


8 


uimsbf 


for (j=0; j< prefix length; j++) { 




uimsbf 


prefix char 

} 

namespace length 


8 


uimsbf 


8 


uimsbf 


for (j=0; j< namespace length; j++) { 






namespace char 
} 
} 

} 


8 


uimsbf 



num_prefixes: This field shall be set to the number of namespaces listed in this structure. 

prefixjength: This field shall be set to the number of bytes in the immediately following prefix. 

prefix_char: This field forms part of a sequence of characters that together form a prefix string that maps to the 
immediately following namespace definition. This field shall be encoded as defined in clause 6.2. 

namespacejength: This field shall be set to the number of bytes in the immediately following namespace entry. 

namespace_char: This field forms part of a sequence of characters that together form a namespace reference. This field 
shall be encoded as defined in clause 6.2. 



9.6 



Metadata Service Identification 



The metadata from one or more CRID authorities may be aggregated into a metadata description. This can be 
considered as containing metadata for all the CRIDs ever issued by these authorities. The metadata description may be 
split into one or more subsets each of which is then encapsulated in a metadata service transmitted in a carousel over the 
air. 

The method by which these subsets may be identified as originating from the same description is using the 
metadata_descriptors_extension in the metadata pointer descriptor or the metadata descriptor, as defined in clause 5.3.4. 
This extension includes the metadata_service_identifier string, which shall be of the form; 

• [ <mds_root > ] "/" <mdd_name> "/" <path_segments> 

Where the format for <path_segments> is defined in RFC 3986 [2]. 
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<mds_root> is a registered internet domain name and must be a fully qualified name according to the rules given by 
RFC 1591 [12]. If it is omitted, the string from the default_authority_descriptor shall be used. 

<mdd_name> is the identifier for the metadata description from which the metadata service has been derived. 

When comparing two metadata service identifiers from separate metadata services, the following rules apply: 

• If the services carry exactly the same metadata, they shall have the same identifier (e.g. "bbc.co.uk/abc/def ). 

• If one service is a subset of the other, the subset service shall have the same identifier as the other service but 
with one or more extra path segments (e.g. "bbc.co.uk/dtt/mds" and "bbc.co.uk/dtt/mds/muxb"). 

When a subset of a metadata description or a metadata service is created, it shall still conform to the profile set out in 
clause 8. Two distinct subsets from the one description or service shall only differ in the inclusion or otherwise of the 
member elements in the following tables: ProgramlnformationTable, GroupInformationTable, ProgramLocationTable, 
ServicelnformationTable, CreditsInformationTable, ProgramReviewTable, SegmentlnformationTable, 
PurchaselnformationTable, ClassificationSchemeTable, MetadataOriginationlnformationTable. 



10 Promotional links 
10.1 Introduction 

The purpose of promotional links is to provide the means to record material related to what the viewer is currently 
watching. For instance, if the viewer is currently watching a trailer for a film a promotional link can be used to give the 
viewer the opportunity to record the film. 

Promotional links relating to a DVB service shall be carried by a related content sub_table (RCT), see clause 10.4 for 
the definition of the RCT. Each link consists of a reference (either a URI string which is likely to be a CRID, a DVB 
binary locator, both a URI and a DVB binary locator, or a descriptor) and promotional text in at least one language. The 
format of this information is based on the tva:RelatedMaterialType (see clause 10.2). The presence of a related content 
sub_table for a particular service is indicated by the related content descriptor (see clause 10.3). 

Promotional links are intended to be used in a real-time manner. While a promotional link is present for the current 
DVB service, a compliant receiver may make the viewer aware of the opportunity to book related material in some way. 
The receiver should present the viewer with the choice of related material, each item being described by the 
promotional text. When the viewer makes his selection the receiver should acquire the related content using the 
provided reference for the selected link. The subsequent removal of promotional links indicates that the receiver should 
cease to provide this opportunity to the viewer. 
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Figure 17 shows an example receiver implementation of promotional links. An actual receiver implementation may 
differ in many ways, for example by waiting for a short period before removing information from the screen. 




Display icon 

indicating related 

material is 

available 




Remove icon 

indicating related 

material is 

available 



Present list of 

related material 

based on last RCT 

acquisition 



No 



-Yes 




Start process of 
obtaining content 
indicated by URI 



Figure 17: Example receiver implementation of promotional links (informative) 
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1 0.2 Restriction of tva:Relatedl\/laterialType 

The format for delivering promotional links is based upon a restriction of the tva:RelatedMaterialType type (see 
TS 102 822-3-1 [4], clause 6.3.4). Table 106 defines these restrictions. 

It is not mandatory to provide metadata for CRIDs included in promotional links. 

Table 106: Restrictions on types relevant to promotional links 



Element Restriction 


mpeg7:MediaLocatorType 


MediaURI 


One instance of this element is present 


InlineMedia 


Not present 


Stream ID 


Not present 


tva:RelatedMaterialType 


Format 


Not present 


PromotionalText 


Present 


SourceMediaLocator 


Not present 



1 0.3 Related content descriptor 



The related content descriptor identifies an elementary stream that delivers a related content sub_table. This descriptor 
may be carried in a PMT sub_table in the descriptor loop for an elementary stream. Only one related_content descriptor 
is permitted in a single PMT sub_table. The syntax of the related content descriptor is defined by table 107. 

Table 107: Related content descriptor 



Syntax 


bits 


format 


related content descriptor () { 

descriptor tag 

descriptor length 
} 


8 
8 


uimsbf 
uimsbf 



descriptor_tag: This eight bit field shall be set to 0x74 (see EN 300 468 [1]). 
descriptorjength: This eight bit field shall be set to the number of bytes that follow it. 

1 0.4 Related content table 
10.4.1 Description 

The related content table (RCT) carries links related to the content currently being broadcast. These links can reference 
related content such as: 

• content being promoted in the audio/visual presentation; 

• the identity of the current item(s) of content being broadcast; 

• metadata related to the current content. 

The intended use of each link is identified by the combination of how_related_classification_scheme_id and term_id. 

NOTE: Where a classification scheme has been extended and there is the need to support legacy receivers then 
the earlier classification scheme should be used to signal terms that are common to both schemes. 

An RCT sub_table is a collection of sections with the same value of table_id, table_id_extension_flag, service_id (if 
table_id_extension_flag = '0') and version number. 
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An RCT sub_table is carried in an elementary stream whose PID is identified by the presence of a related content 
descriptor in the corresponding elementary stream descriptor loop of the current service's PMT (see clause 10.3). The 
stream_type for an elementary stream carrying an RCT sub_table must be set to 0x05, indicating private sections (see 
ISO/IEC 13818-1 [9], table 2-29). 

When the related content descriptor is present in the PMT an RCT sub_table shall be present and it shall be transmitted 
at least once every 30 seconds. The RCT may be transmitted more frequently to improve receiver responsiveness for 
more time-critical related content. Receivers that are capable of using related material data may constantly monitor for 
its presence. 

The time at which a related material is no longer being promoted is signalled by removing the specific link information 
from the related content table. A sub_table with link_count set to zero shall be transmitted if there are currently no 
related materials. 

10.4.1.1 Current Content 

The RCT can carry links with the term_id set to urn:dvb:cs:HowRelatedExtensionCS:2007:l ("Current Broadcast") to 
identify the CRID of the content currently being broadcast. More than one link of this type may be carried if there is 
more than one current item of content (e.g. nested or overlapping content). 

10.4.1.2 Segmentation 

If an RCT carries a link with a term_id that indicates segmentation then that link references segmentation metadata 
which is currently being delivered or will be delivered in the current transport stream. The term_ids 
urn:tva:cs:HowRelatedCS:2007:15.1 ("Static Segmentation"), urn:tva:cs:HowRelatedCS:2007:15.2 
("Live Segmentation"), urn:tva:cs:HowRelatedCS:2007:15.3 ("Live & Post Segmentation"), 
urn:tva:cs:HowRelatedCS:2007:15.4 ("Post Segmentation") shall be used to indicate the dynamic status of the 
segmentation metadata. 

NOTE: The use of the term_ids of urn:tva:metadata:HowRelatedCS:2004; 15 ("Segmentation"), 

urn:tva:metadata:HowRelatedCS:2007:15 ("Segmentation") is discouraged as it is not possible from these 
to determine the dynamic status of the segmentation metadata. 

If a link of any segmentation type is carried, then a metadata pointer descriptor with a fragment_type field of value 
OxOOOD (indicating segment group information) shall be carried either in the descriptor loop for this link or the 
descriptor loop for the current service in the SDT actual. The link_type in this case shall be 0x03 ("Descriptor Link"). 
There shall only be at most one metadata pointer descriptor in the descriptor loop for this link, which if present shall 
take precedence over any metadata pointer descriptor in the descriptor loop for the current service in the SDT actual. 

1 0.4.1 .3 Opportunity to Acquire Content 

If an RCT carries one or more links with a term_id value other than those detailed in clauses 10.4.1.1 and 10.4.1.2 the 
receiver could indicate to the viewer that there is the opportunity to acquire content. The way in which the user is 
prompted, or the conditions under which the list of available content is presented, are not part of the present document. 
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10.4.2 Syntax 

Each RCT sub_table shall be delivered as sections as defined by table 108. 

Table 108: Related content section 



Syntax 


No. of bits 


Identifier 


related content section () { 






table_id 


8 


uimsbf 


section syntax indicator 


1 


bslbf 


table id extension flag 


1 


bslbf 


reserved 


2 


bslbf 


section length 


12 


uimsbf 


service id 


16 


uimsbf 


reserved 


2 


bslbf 


version number 


5 


uimsbf 


current next indicator 


1 


bslbf 


section number 


8 


uimsbf 


last section number 


8 


uimsbf 


year offset 


16 


uimsbf 


link count 


8 


uimsbf 


for (j=0; j<link count; j++) { 






reserved 


4 


uimsbf 


link info length 


12 


uimsbf 


link infoO 

} 

reserved future use 






4 


bslbf 


descriptor_loop length 


12 


uimsbf 


for (k=0; k<descriptor loop length; k++) { 






descriptor ( ) 

} 

CRC 3 2 

} 






32 


rpchof 



tablejd: This is an eight bit field that shall be set to 0x76 (see EN 300 468 [1]). 

section_syntax_indicator: This is a one-bit indicator which shall be set to '1'. 

table_id_extension_flag: This is a one -bit indicator. When set to '0' it indicates that the table_id_extension (service_id) 
shall be used in decoding this sub_table. When set to '1' it indicates that all related content sections in the current 
sub_table relate to a single service and the service_id shall be ignored. 

reserved, reserved_future_use: All bits of fields marked as being reserved or reserved_future_use shall be set to '1'. 

sectionjength: This is a twelve bit field. It specifies the number of bytes of the section, starting immediately following 
the sectionjength field and up to the end of the section. The maximum allowed value of sectionjength is 4 093. 

service Jd: The servicejd indicates the service to which the related content information in this sub_table refers. This is 
a 16-bit field which serves as a label to identify this service from any other service within the TS. The servicejd is the 
same as the program_number in the corresponding program_map_section. This field shall be ignored if the 
table Jd_extension_flag is set to '1'. 

version_number: This 5-bit field is the version number of the sub Jable. The version_number shall be incremented by 
1 when a change in the information carried within the sub_table occurs. When it reaches value 31 Jt wraps around to 0. 

current_nextJndicator: This 1-bit indicator shall be set to '1'. 

section_number: This 8-bit field gives the number of the section. The section_number of the first section in the 
sub_table shall be "0x00". The section_number shall be incremented by 1 with each additional section with the same 
tablejd, tableJd_extension_flag and servicejd. 

last_section_number: This 8-bit field indicates the number of the last section (that is, the section with the highest 
section_number) of the sub_table of which this section is part. 

year_offset: The year relative to which date values in this structure shall be calculated. This field shall be encoded as 
the binary value of the year, for example "2003" would be encoded as 0x07D3. 
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link_count: This is an eight bit field. It specifies the number of related material references in this section. 

link_info_length: This 12-bit field gives the length of the following link_info() structure. 

descriptor_loop_length: This field shall be set to the total length in bytes of the following descriptors. 

CRC_32: This is a 32-bit field that contains the CRC value that gives a zero output of the registers in the decoder 
defined in annex B of EN 300 468 [1] after processing the entire section. 

1 0.4.3 Link info structure 

The syntax of the link info structure of the related content section is defined by table 109. 

Table 109: Link info structure 



Syntax 


No. of bits 


Identifier 


link_info{) { 






link type 


4 


uimsbf 


reserved_future_use 


2 


bslbf 


how_related classification scheme id 


6 


uimsbf 


term id 


12 


uimsbf 


group id 


4 


uimsbf 


precedence 


4 


uimsbf 


if {link_type == 0x00 | | link_type == 0x02) { 






media uri length 


8 


uimsbf 


for {k=0; k<media uri length; k++) { 






media uri byte 
} 


8 


uimsbf 


} 

if {link type == 0x01 | | link type == 0x02) { 






dvb binary locator {) 

} 

reserved_future use 






2 


bslbf 


number items 


6 


uimsbf 


for {m=0; m<number items; m++) { 






ISO 639-2 [23]_language_code 


24 


bslbf 


promotional text length 


8 


uimsbf 


for {n=0; n< promotional text length; n++) { 






promotional text char 
} 


8 


uimsbf 


} 

default icon flag 


1 


bslbf 


icon id 


3 


uimsbf 


descriptor loop length 


12 


uimsbf 


for {p=0; p<descriptor loop length; p++) { 






descriptor { ) 
} 
} 


8 


uimsbf 



link_type: This field indicates the format of the link information contained within this structure. This link information 
may consist of a URI (e.g. a CRID), a DVB binary locator, both a URI and a DVB binary locator, or a descriptor. 

If the link information consists of a CRID URI and a binary locator, the binary locator should be considered an 
indication of the likely broadcast time and location, the location the CRID resolves to should be considered the 
authoritative broadcast time and location. The semantics of the link information consisting of a different URI type and a 
binary locator are not defined. 

If the link information consists of a descriptor then that descriptor shall be carried in the descriptor loop for this link or 
the descriptor loop for the current service in the SDT actual. A descriptor in the descriptor loop for this link shall take 
precedence over the same type of descriptor in the descriptor loop for the current service in the SDT actual. 
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This field shall be encoded according to table 110. 

Table 110: linktype 



Value 


Description 


0x0 


Link information is a URI string only 


0x1 


Linl< information is a binary locator only 


0x2 


Link information is both a binary locator and a URI string 


0x3 


Link information is through means of a descriptor 


0x4 to OxF 


DVB reserved 



reserved_future_use: All bits of fields marked as being reserved_future_use shall be set to '1'. 

how_related_classification_scheme_id: This field identifies the classification scheme of the encoded term_id. The 
field shall be encoded according to table 11 1 . If the how_related_classification_scheme_id value is not supported by the 
receiver the link_info structure should be ignored. 

Table 111: how related classification scheme id 



Value 


Description 


0x00 


urn:tva:metadata:HowRelatedCS;2004 [25], clause A.3. 


0x01 


urn:tva:metadata:HowRelatedCS:2005 [26], clause A.3. 


0x02 


urn:tva:metadata:HowRelatedCS:2007 [4], clause A.3. 


0x03 to 0x2 F 


DVB reserved 


0x30 to 0x3 F 


User Private 



term_id: The rank of the element in the classification scheme. The rank of the first term according to document order 
shall be zero. The term_id defines the relationship between the content being broadcast and the content referenced by 
this link. 

group_id: This field allows link_info structures using different classification schemes within the same sub_table to be 
grouped together to allow an order of precedence to be expressed between them. Link_info structures with the same 
group_id belong to the same group. A group_id of OxF indicates that there is no relative precedence and all links in the 
group shall be used where the how_related_classification_scheme_id is supported by the receiver. For all other values 
of group_id the precedence field shall be used to determine how the links are handled. 

precedence: The precedence field is used to indicate an order of preference for the link info structures within a group as 
defined by the group_id. All link_info structures within a group with a how_related_classification_scheme _id that is 
not supported by the receiver shall be ignored. Of the remaining link_info structures in the group only those that have 
the highest remaining precedence value shall be used. Any link_info structures with a lower precedence value shall be 
ignored. If the group_id is set to OxF then the precedence field shall be ignored. 

When several classification schemes are used within a sub_table (e.g. to support legacy receivers) the group_id and 
precedence fields can be used to control the behaviour of receivers that support more than one of the classification 
schemes. 

media_uri_length: If this field is present it shall be set to the number of media_uri_bytes that follow. 

media_uri_byte: This field is part of a sequence that forms the MediaUri string. This string shall be a URI. If it is a 
CRID this string may use the abbreviated format (see clause 6.3). No other URIs may be abbreviated and must include 
the protocol part. The CRID authority part of the CRID may only be omitted if there is a default authority defined for 
the scope of the DVB service this related content section relates to. 

dvb_binary_locator(): See clause 7.3.2.3.3 for definition. The year_offset value used by the DVB binary locator is 
defined in the enclosing related content section (see clause 10.4.2). The inline_service flag of the DVB binary locator 
shall be set to '1'. 

number_items: This field shall be set to the number of items in the following multilingual promotional text loop. 

ISO 639-2_language_code: This field shall be set to the ISO 639-2 [23] code that describes the language of the 
following text field. 

promotional_text_length: This field shall be set to the number of bytes in the following promotional text string. 
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promotional_text_char: This field is part of a sequence that forms the promotional text for the language given. Text 
information shall be encoded using the character sets and methods described in annex A of EN 300 468 [1]. 

default_icon_flag: This flag indicates whether the receiver's default mechanism may be used if an icon has been 
signalled but acquisition has not, or cannot, be completed successfully. The flag should be set to '1' if the receiver's 
default mechanism may be used or '0' if it shall not be used. 

icon_id: This 3-bit field identifies an icon carried in an image_icon_descriptor in the link_info descriptor loop or RCT 
descriptor loop of the current structure (see EN 300 468 [1]). Image_icon_descriptors found in the link_info descriptor 
loop take precedence over any image_icon_descriptors in the RCT descriptor loop that have the same value of icon_id. 
If the value of this field is set to '000' and the default_icon_flag is set to '1' then the receiver's default mechanism shall 
be used. If the value of this field is set to '000' and the default_icon_flag is set to '0' then the receiver shall not render 
anything to represent the link (e.g. an icon is already rendered in the video). 

Where the image data is referenced from the image icon descriptor (as opposed to being carried inline) then the receiver 
will have to enact a secondary acquisition of the image data, either through an object carousel, IP connection, or some 
other means. If this acquisition has not completed by the time the image icon is required then a receiver may have the 
option to use a default inbuilt icon. 

Whether a receiver uses an icon signalled by an image_icon_descriptor or an inbuilt icon is determined by a 
combination of default_icon_flag and icon_id. The relative meaning of which is shown in table 112. 

Table 112: default icon signalling 



defaultjconflag 


icon id 


Description 


'0' 


0x0 


Do not render anything e.g. an icon is already rendered in tlie video. 


'0' 


0x1 to 0x7 


Render icon signalled by descriptor (and only this). 


'1' 


0x0 


Render receiver default icon. 


'1' 


0x1 to 0x7 


Render icon signalled by descriptor by preference but if this is not yet 
cached (URL only mechanism) use receiver default icon. The default 
icon shall be positioned using the coordinates signalled in the 
image icon descriptor, if specified. 



descriptor_loop_length: This field shall be set to the total length in bytes of the following descriptors. 
NOTE: The descriptor loop is included for future extension. 



1 1 Accurate recording 
11.1 Modes of operation 

The DVB locator (see clause 6.4), supports two modes for signalling the broadcast of an event. The BiM DVB locator 
codec (see clause 9.4.3.4) and the DVB_binary_locator sub-structure (see clause 7.3.2.3.3) also support this feature. In 
the DVB_binary_locator sub-structure the mode in use is signalled by the identifier_type field. 

The first mode is to use scheduled time and is signalled when the identifier_type is '00'. In this case the receiver uses its 
internal clock to control the start and end of recording based on the times indicated by the start_time and duration fields. 
The start_time and duration fields offer the best estimate of when the content will be broadcast. Ideally, such CRI data 
should be updated to reflect any changes shortly before or during broadcast to provide more accurate information. 

To offer increased reliability of capture a receiver may employ guard intervals either side of the scheduled start_time 
and implicit scheduled end time. In determining the size of these guard intervals the receiver may consider the 
early_start_window and late_end_window, if provided by the broadcaster for the particular item of content to be 
recorded. The intention is that the early_start_window and late_end_window fields should be considered an estimate of 
the maximum by which the broadcast time may differ from the scheduled time. 

The scheduled time information provided in CRI, including the early_start_window and late_end_window, does not 
imply anything about previous and subsequent events. For example, the scheduled start of an event (from information in 
the CRI data) does not imply that the previous event on this service has finished. 
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The second mode relies on detecting the presence of event_identifiers in the broadcast stream and is signalled when the 
identifier_type is either '01' or '10'. In its simplest form this mode relies on monitoring the presence of the relevant 
event_id in the present event of EIT p/f. In a refinement of this mode the receiver may monitor for the presence of the 
TVA_id, also carried in the present event of EIT p/f. The main advantage of the TVA_id over the event_id is that the 
service provider is free to control the presence of a TVA_id in the broadcast stream independently of the flow of EIT 
events. This allows the broadcaster to accurately identify when particular content is being delivered. In addition there 
can be more than one active TVA_id at any instance, enabling nesting and overlapping of content. 

NOTE: One of the issues for a receiver implementation in providing support for this mode is the strategy for how 
and when to look for the presence of the relevant event_identifier in the broadcast stream. An obvious 
candidate is to use the scheduled start_time and duration to define a "monitoring window". However, it 
should not be assumed that a service provider is always able to update an item of content's scheduled start 
time and duration before changes to the actual start time and duration occur. In extreme cases the 
programme may start before its scheduled start time or after it is scheduled to have finished. Despite this, 
the broadcast of either event_id and/or TVA_id may still enable accurate recording. 

It is possible that a broadcast may contain information apparently supporting more than one of these modes for a 
particular event. For example, the service provider may provide start_time and duration even when signalling the use of 
an event_identifier simply to support clash detection during booking. However, there is no requirement to ensure 
consistency between this information and broadcast signalling should be used as a guide to the most reliable mode. 

See annex A for an example receiver implementation supporting these modes of operation. 

1 1 .2 Carriage of TVAJds 
11.2.1 Introduction 

This clause defines the mechanism by which a TVA_id shall be carried in the broadcast stream, so creating an 
association with content currently being transmitted. The advantages of the use of the TVA_id for identifying content to 
record over the use of the EIT event_id are as follows: 

• It allows the broadcaster to identify an item of content at a granularity that is finer than that of an EIT event. 

• It allows broadcasters to indicate the actual transmission of an item of content more accurately than may be 
possible using EIT event_id. 

• Since multiple TVA_ids may be present for a single DVB service it allows broadcasters to indicate the start 
and stop of a number of overlapping items of content. 

The association of an item of content with a particular TVA_id is made within a DVB locator as carried in the CRI (see 
clause 7.3.2.3.3) or within TVA metadata (see clause 8). The association of the same TVA_id with some specific 
content, and so by inference the item of content with this content, is made using the TVA_id_descriptor. 



11.2.2 Carriage in EIT 

When carried in EIT, the TVA_id_descriptor shall be placed in the descriptor loop for the present event in the EIT 
present/following. Specific values of TVA_id shall be carried by a TVA_id_descriptor placed in the EIT 
present/following sub_table for the DVB service in which the item of content is broadcast. Where a TVA_id is being 
signalled, placement of an appropriate TVA_id_descriptor in EIT present/following actual TS is mandatory, whilst 
placement of an appropriate TVA_id_descriptor in EIT present/following other TS is optional. 

The TVA_id_descriptor can list one or more TVA_ids and more than one instance of the TVA_id_descriptor can be 
placed in a single descriptor loop for the present event in EIT present/following. This enables the signalling of 
overlapping and/or nested events. 

11.2.3 Carriage in PES 

When carried in PES, the TVA_id_descriptor shall be placed in the auxiliary data structure with the payload format 
field set to 0x1, as defined in TS 102 823 [21], clause 4.5. For a particular service, the elementary stream carrying the 
relevant synchronized auxiliary data stream shall be identified by the value of component tag in any DVB locator 
referencing content broadcast on that service. 
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1 1 .2.4 TVAJd descriptor 

The TVA_id_descriptor can list one or more TVA_ids. It also allows a state to be associated with a specific value of 
each TVA_id listed. This can be used by the receiver as part of its strategy of managing the recording process. 

The syntax of the TVAJd descriptor is defined by table 113. 

Table 113: TVAJd descriptor 



Syntax 


No. of bits 


Identifier 


TVA id descriptor { 






descriptor tag 


8 


uimsbf 


descriptor length 


8 


uimsbf 


for (i=0; i<N; i++) { 






TVA_id 


16 


uimsbf 


Reserved 


5 


uimsbf 


running status 
} 
} 


3 


uimsbf 



descriptor_tag: If this descriptor is carried in a section this field shall be set to the value 0x75 (see EN 300 468 [1]). If 
this descriptor is carried in synchronized auxiliary data this field shall be set to the value 0x01 (see TS 102 823 [21], 
clause 5.1. 

descriptorjength: This 8-bit field specifies the total number of bytes of the data portion of the descriptor following the 
byte defining the value of this field. 

TVAJd: This 16-bit field shall be set to the value of TVAJd that refers to the item of content being signalled. 

running_status: This 3-bit field indicates the status of the item of content associated with a particular value of TVAJd. 
The possible values for this field are defined in table 1 14. 

Table 114: Running status 



Value 


Meaning 


Description 





Reserved 




1 


Not yet running 


Receivers shall treat the item of content as not yet running. 

This can be used when the item of content is still to be broadcast, but is unlikely to 

start until sometime after the most recently indicated scheduled start time. 


2 


Starts (or restarts) 
shortly 


Receivers shall prepare for the change of runningstatus to "running" to occur 

shortly. 

This optional mode can be used to assist receivers in preparing their resources for 

recording. If used this value should be signalled for 30 seconds before changing to 

"Running". 


3 


Paused 


Receivers shall treat the item of content as paused. 

This can be used when broadcast of the item of content has already started, but at 

this time the content being broadcast is not a part it. It is assumed that the 

transmission of relevant content will resume at a later time. 

It is recommended that the paused state is only used for short interruptions not 

appearing in the schedule. 


4 


Running 


Receivers shall treat the item of content as running. 

This can be used to indicate that at this time the content being broadcast is part of 

the item of content. 


5 


Cancelled 


Receivers shall treat the item of content as cancelled. 

This can be used to indicate that the item of content has been pulled either before 
commencement of, or part way through transmission. It is recommended that this 
is signalled for 10 seconds. 


6 


Completed 


Receivers shall treat the transmission of item of content as being completed. It is 
recommended that this is signalled for 10 seconds. 


7 


Reserved 
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The relationship between the various states is illustrated by figure 18. 



Item of Content not yet 
broadcast. 

Associated tva_id not 
carried in EIT-present. 



item of Content eitfier 

successfully broadcast 

or pulled from 

transmission sctiedule. 

Associated tva_id not 

carried in EIT-present. 



m 



■c 



[Cancelled] 




V. [Not yet running] J 



■c 



[Starts stiortly] 



■c 



> 



3 

[Paused] 



[Running] 



c 



> 




v_ ]' 



[completed] 



Figure 18: TVAid UML state diagram 



12 Extensions to DVB SI 

12.1 Content identifier descriptor 
12.1.1 Introduction 

The content identifier descriptor allows a CRID to be assigned to an event entry in an EIT sub_table, so providing a hnk 
to CRI or to metadata for that event's content. One or more instance of this descriptor may be carried in the event 
descriptor loop of an EIT schedule section or an EIT present/following section. There is no requirement for all EIT 
events to have a CRID assigned to them. 

NOTE 1: The selection of events for recording using event entries in an EIT sub_table that do not contain a CRID 
is not considered in the present document. 

The content identifier descriptor supports two methods for defining the CRID to be associated, the CRID can be 
explicitly included in the descriptor or the descriptor can refer to a CRID carried in a separate sub_table (an "indirect 
definition"). These methods of definition are interchangeable and each CRID included in a content identifier descriptor 
may be defined using any of these methods. 

The use of explicit CRID definition is recommended for interoperability. 
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NOTE 2: A CRID is simply an identifier. The encodings supported by the content identifier descriptor are only 

provided to give the broadcaster some flexibility about how a particular CRID is defined. Once a receiver 
has extracted the CRID from a particular encoding it should simply treat this, like any other CRID, as just 
an identifier. 

12.1.2 Explicit CRID definition 

The first method is to explicitly carry the encoded CRID in the descriptor. The CRID may be encoded using the 
abbreviated CRID rules (see clause 6.3.1). If the CRID authority part is omitted there shall be a default authority 
defined for a scope encompassing the DVB service that the EIT relates to (see clause 6.3.2). 

12.1.3 Indirect CRID definition 

The second method is to refer to a CRID entry in a separate structure that is associated with the DVB service that the 
event forms part of. In this case the descriptor carries an identifier that uniquely identifies the relevant CRID in a 
sub_table of the Content Identifier Table (CIT). 

12.1.4 Syntax 

The syntax of the content identifier descriptor is defined by table 115. 

Table 115: Content identifier descriptor 



Syntax 


No. of bits 


Identifier 


content identifier descriptor {) { 






descriptor tag 


8 


uimsbf 


descriptor length 


8 


uimsbf 


for {i=0;i<N;i++) { 






crid type 


6 


uimsbf 


crid location 


2 


uimsbf 


if {crid_location == '00' ) { 






crid length 


8 


uimsbf 


for {j=0;j<crid length; j++) { 






crid byte 
} 


8 


uimsbf 


} 

if {crid location == '01' ) { 






crid ref 
} 
} 
} 


18 


uimsbf 



descriptor_tag: This field shall be set to 0x76 (see EN 300 468 [1]). 

descriptorjength: This field shall be set to the number of bytes in this descriptor following this field. 

crid_type: This field defines the type of CRID that this content labelling descriptor describes. This field shall be 
encoded according to table 116. 

Table 116: CRID type 



Value 


Semantics 


0x00 


No type defined. 


0x01 


CRID references the item of content that this 
event is an instance of. 


0x02 


CRID references a series that this event 
belongs to. 


0x03 


CRID references a recommendation. This 
CRID can be a group or a single item of 
content. 


0x04 to 0x1 F 


DVB reserved. 


0x20 to OxSF 


User private. 
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cridjocation: This field describes the location of the CRID information. This field shall be encoded according to 
table 117. 

Table 117: CRID location 



Value 


Semantics 


'00' 


Carried explicitly within descriptor. 


'01' 


Carried in Content Identifier Table (CIT). 


'10' 


DVB reserved. 


'11' 


DVB reserved. 



cridjength: This field shall be set to the number of crid_bytes that follow. 

crid_byte: This field forms part of a sequence of bytes that defines an explicitly encoded CRID (see clause 12.1.2). 
When the CRID authority part of the CRID URL is not present the forward-slash character ("/") immediately following 
the CRID authority part must be present. 

This field may carry an IMI in addition to the CRID. In this case, the CRID is terminated by a "#" character which is 
followed immediately by the IMI. The first four bytes of the IMI (i.e. "imi:") shall be omitted. 

crid_ref: When cridjocation is set to '01' this field defines the identifier by which the relevant CRID can be discovered 
in the Content Identifier Table for this DVB service. 



1 2.2 Content identifier table (CIT) 



Event label data may be carried in CIT sub_tables comprising content_identifier_sections. The format for this type of 
section is derived from the standard private section syntax as defined in ISO/IEC 13818-1 [9]. 

A CIT sub_table provides CRID labels for BIT schedule sub_tables relating to one DVB service. One CIT schedule 
sub_table is defined by a combination of service_id, transport_stream_id and original_network_id. 
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The semantics of the CIT are defined by table 118. Sections forming part of the CIT shall be carried in TS packets with 
a PID value of 0x00 12. 

Table 118: Content identifier section 



Syntax 


No. of bits 


Identifier 


Content identifier section () { 






table_id 


8 


uimsbf 


section syntax indicator 


1 


bslbf 


private_indicator 


1 


bslbf 


reserved 


2 


bslbf 


section length 


12 


uimsbf 


service id 


16 


uimsbf 


reserved 


2 


bslbf 


version number 


5 


uimsbf 


current next indicator 


1 


bslbf 


s e c t i on_numbe r 


8 


uimsbf 


last section number 


8 


uimsbf 


transport stream id 


16 


uimsbf 


original network id 


16 


uimsbf 


prepend strings length 


8 


uimsbf 


for (i=0; i< prepend strings length ; i++) { 






prepend strings byte 

} 

for (j=0; j<N; j++) { 


8 


uimsbf 






crid ref 


16 


uimsbf 


prepend string index 


8 


uimsbf 


unique string length 


8 


uimsbf 


for (k=0; k<unique_string length; k++) { 






unique string byte 
} 


8 


uimsbf 


} 
CRC3 2 

} 


32 





tablejd: This field shall be set to 0x77 (see EN 300 468 [1]). 

section_syntax_indicator: This shall be set to '1' to indicate that the private section follows the generic section syntax. 

private_indicator: This flag shall be set to '1'. 

sectionjength: The number of remaining bytes in the private section immediately following the section_length field up 
to the end of this event label map section. 

service_id: This shall contain the container_id of the container carried by the table this section is part of. 

version_number: The version of the table. 

current_next_indicator: This field shall be set to '1' to indicate that the section is currently valid. 

sectioii_number: This field specifies the number of the section. This section_number will be incremented by 1 with 
each additional section with the same service_id, transport_stream_id and original_network_id. 

last_section_number: This specifies the number of the last section making up this table. 

transport_stream_id: This field identifies the TS that carries the indicated DVB service. 

original_network_id: This field identifies the network_id of the originating delivery system. 

prepend_strings_length: This field gives the total number of bytes of prepend strings that follow this field. 

prepend_strings_bytes: This field forms part of a sequence that is a concatenation of prepend strings. Each prepend 
string contained with this partition shall be partitioned by a byte with value 0x00. Prepend strings are referenced by 
index, the first prepend string having an index value of and the second an index value of 1 . 
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crid_ref: This field assigns a reference value for this CRID. This value is referenced from the content identifier 
descriptor of the EIT. Only one CRID may be assigned this value of crid_ref in all CIT sections with the same 
service_id and original_network_id. 

prepend_string_index: This field gives the index of the relevant prepend_string in the list of prepend_strings carried in 
this section. If this field is set to OxFF then there is no prepend_string and the unique_string shall hold the complete 
CRID string. The complete CRID string need not contain the first 7 characters common to every CRID (i.e. "CRID://"), 
if this is the case then their presence is implied. 

unique_string_length: This field gives the length, in bytes, of the unique_string immediately following this field. 

unique_string_byte: This field forms part of a sequence that together forms the unique_string. The unique_string shall 
not be null terminated. Concatenating the prepend_string for this entry with the unique_string gives a full CRID 
reference which may include an IMI. When an IMI is included the CRID shall be terminated by a "#" character which is 
followed immediately by the IMI. The first four bytes of the IMI ("imi:") are always omitted. 

CRC32: This is a 32-bit field that contains the CRC value that gives a zero output of the registers in the decoder 
defined in EN 300 468 [1], annex B after processing the entire private section. 
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Annex A (informative): 
Example recorder behaviour 



Clause 1 1 specifies the different signalling that the broadcaster may provide for recording programme items based on 
the identifier_type field of the result_data CRI structure. This informative annex does not form a normative part of the 
present document but gives an illustrative example of a possible receiver implementation. 

Figure A.l shows these different modes of operation based on whether the identifier_type field is set to "not used", 
event_id or TVA_id. A receiver needs to be able to deal with a mixture of signalling modes present in a network as 
different broadcasters and programmes may support some modes and not others. 
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Figure A.1 : Example strategy for controlling recording 
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However, this strategy does not represent the only solution. For example: 

• If the actual programme transmission starts before the receiver has begun to monitor for a programme it will 
not be completely recorded. 

• If two programmes are to be recorded "back-to-back" it may not be possible to blindly apply the 
early_start_window and late_end_window as provided by the broadcaster. 

• In an alternative model a receiver may apply different adjustments to those suggested by the broadcaster or no 
adjustments at all. 

• The "starts shortly" state of TVA_id signals to a receiver that it should prepare resources to start recording, this 
could also include increasing the rate of TVA_id monitoring. 

• It does not indicate how the receiver should deal with an item in the list of programmes to record after the 
monitoring for its event_identifier was terminated by the receiver before starting recording, e.g. because it was 
time to record the next item in the list. 

• This does not indicate what a receiver should do in the paused recording state, it may, for example, be able to 
record a different programme during the pause. 

From this it should be clear that a range of strategies may be implemented based on the structure and size of the 
network, whether full cross-carriage of information is available and the physical resources of the receiver. 
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Annex B (informative): 

Example BilVI format for ScheduleEvent fragment 



B.1 TVA Schedule Schema 



The following is a portion of the TVA Schema as defined in TS 102 822-3-1 [4]. It defines the Schedule type used in 
this example. 



<element .,,. c^" Schedule" type="tva: ScheduleType"> 

<complexType name= " InstanceDescript ionType " > 
<sequence> 

<element name="Title" type="mpeg7 :TitleType" minOccurs="0"/> 
<element name="Synopsis" type="tva:SynopsisType" minOccurs="0"/> 
<element name="AVAttributes" type="tva:AVAttributesType" minOccurs="0"/; 
</sequence> 
</complexType> 



'Program" tYpe="tva: CRIDRef Type"/> 

'ProgramURL" type="anyURI" minOccurs="0"/> 

' InstanceMetadatald" type= " tva : InstanceMetadataldType " minOccurs= " " 

'InstanceDescript ion" type="tva: InstanceDescript ionType" 

'0"/> 

'PublishedStartTime" type="dateTime" minOccurs="0"/> 

'PublishedEndTime" type="dateTime" minOccurs="0"/> 

'PublishedDuration" type= "duration" minOccurs="0"/> 

'Live" type="tva: FlagType" minOccurs="0"/> 

'Repeat" type=" tva: FlagType" minOccurs="0"/> 

'FirstShowing" type=" tva: FlagType" minOccurs="0"/> 

'LastShowing" type=" tva: FlagType" minOccurs="0"/> 

'Free" type=" tva: FlagType" minOccurs="0"/> 



<attributeGroup name="f ragmentldentif ication"> 

<attribute name="f ragmentid" type="tva:TVAIDType" Lise="optional"/> 
<attribute name="f ragmentVersion" type="unsignedLong" Lise="optional"/> 

</attributeGroup> 

<complexType name= " ScheduleType " > 

<sequence> 

<element name=" ScheduleEvent" type="tva: ScheduleEventType" maxOccurs= "unbounded" /> 

</sequence> 

<attribute name="serviceIDRef " type= " tva :TVAIDRef Type" use="required"/> 

<attribute name="start" type="dateTime" use= "optional "/> 

<attribute name="end" type="dateTime" use= "optional "/> 

<attributeGroup "ef ="tva: fragmentldentif ication"/> 
</complexType> 



<complexType "Schedul 


< complexContent > 




<sequence> 




<element 


;iame= 


<element 


iiame= 


<element 


name= 


<element 


name= 


•iinOccurs = 


<element 


name= 


<element 


name= 


<element 


name= 


<element 


name= 


<element 


name= 


<element 


name= 


<element 


name= 


<element 


name= 


</sequence> 




< /complexContent > 


</complexType> 
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B.2 TVA Schedule Instance: Textual Coding 

The following is a portion of a TV-Anytime instance document that describes a schedule fragment. 



<Schedule servicelDRef ="dvb: //1234 . . 0001" 
5tart="2003-03-04T12:00" 
end="2 003-03-04T17:00"> 
<ScheduleEvent> 

<Program "crid: //Ia2b3c4d" /> 

<ProgramURL>dvb://1234. . 0001 ; 100102 003 -03 -04T14 : 01 : 3 OZ- -PT00H58M15S</ProgramURL> 

<InstanceDescription> 

<Title>Footie</Title> 

<Synopsis>Kick;ing around a pig's bladder . </Synopsis> 
</InstanceDescription> 

<PublishedStartTime>2003-03-04T14 : 00 : 00</PublishedStartTime> 
<PublishedDuration>PT01H00M00S</PublishedDuration> 
</ScheduleEvent> 
</Schedule> 



B.3 TVA Schedule Instance: Binary Coding 

Table B.l is an example encoding of the schedule fragment given in clause B.2. 

Table B.1 : Binary encoding of example schedule instance 



Syntax 


Value 


Notes 


FragmentUpdatePayload { ) { 






DecodingModes { ) { 






lengthCodingMode 


00 


No element lengths are encoded 


hasDef erredNodes 





No 


hasTypeCasting 





No 


reservedBits 


1111 




} 






Element (Schedule) { 


- 


PayloadlopLevel Element so no transition to 
encode 


Attributes {) { 






Attr{End) { 


1 


Optional attribute encoded 


dvbDateTimeCodec ( ) 


10 


[16 bits] 
[1 1 bits] 


a Published Time is encoded 

do not reuse previous date 

date 

time (minutes since 00:00:00) 


} 






Attr (Fragmentld) 





Optional attribute not encoded 


Attr (FragmentVersion) 





Optional attribute not encoded 


Attr {ServicelDRef ) { 


- 


Mandatory attribute 


dvbStringCodec ( ) 


- 


see dvbStringCodecO; data taken from string buffer 


} 






Attr (Start) { 


1 


Optional attribute is encoded 


dvbDateTimeCodec { ) 


10 

1 

[1 1 bits] 


a Published Time is encoded 
reuse previously encoded date 
time (minutes since 00:00:00) 


} 






} 






Content {) { 




ComplexContent 


Sequence { ) { 






ScheduleEvent {) { 






NumberOf Occurrences 


0001 


Unbounded in schema but only one in this instance 


Element (ScheduleEvent) { 






Attributes () 




No attributes 


Content ( ) { 




ComplexContent 


Element (Program) { 


- 


Mandatory element 


Attributes () { 






Attr (crid) { 




Mandatory attribute 
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Syntax 


Value 


Notes 


dvbDVBLocatorCodec ( ) { 




dvbLocatorCodec used since CRIDs are of type 
any URI. Data encoded 


Optimized codec flag 





GRID is encoded as a string 


dvbStringCodec ( ) 


- 


see dvbStringCodecO; data tal<en from string buffer 


} 






} 






Content ( ) 




no content 


} 






Element (ProgramURL) { 


1 


Optional element is encoded 


Attributes () 


- 


No attributes 


Content ( ) { 




SimpleType 


dvbDVBLocatorCodec ( ) { 




See dvbLocatorCodec. 


Optimized codec flag 


1 


Use the OptimizedDVBLocator encoding 




1 


DVBLocatorPrefix is encoded 




[16 bits] 


transport stream id 




[16 bits] 


original network id 




[16 bits] 


service id 







No component tag field encoded 




01 


event id is encoded 




[16 bits] 


event id data 




1 


Time and date are encoded 




1 


day is encoded 




[16 bits] 


Date data 




[17 bits] 


time data 




[17 bits] 


duration data 







No path segment data encoded 


} 






} 






} 






Element (InstMetadatald) 





Optional element not encoded, i.e. shunt transition 


Element (InstDescription) { 


1 


Optional element is encoded 


Attributes () 


- 


No attributes 


Content ( ) { 




ComplexContent 


Sequence ( ) { 






Element (Title) { 


1 


Optional element is encoded 


Attributes 




No attributes 


Content ( ) { 




SimpleType 


dvbStringCodec ( ) 


- 


see dvbStringCodecO; data taken from string buffer 


} 






} 






Element (Synopsis) { 


1 


Optional element is encoded 


Attributes () 




No attributes 


Content ( ) { 




SimpleType 


dvbStringCodec ( ) 


- 


see dvbStringCodecO; data taken from string buffer 


} 






} 






Element (Genre) 





Optional element not encoded 


Element (AVAttributes) 





Optional element not encoded 


Element (MemberOf ) 





Optional element not encoded 


} 






} 






Element (PublishedStartTime) { 


1 


Optional element is encoded 


Attributes () 


- 


No attributes 


Content ( ) { 




SimpleType 


dvbDateTimeCodec ( ) 


10 

1 

[1 1 bits] 


a Published Time is encoded 
reuse previously encoded date 
time (minutes since 00:00:00) 


} 






} 






Element (PublishedEndTime) 





Optional element not encoded 


Element (PublishedDuration) { 


1 


Optional element is encoded 


Attributes () 


- 


No attributes 


Content ( ) { 




SimpleType 
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Syntax 


Value 


Notes 


dvbDurationCodec ( ) 


1 
[1 1 bits] 


optimized encoding 
number of minutes 


} 






} 






Element (Live) 





Optional element not encoded 


Element (Repeat) 





Optional element not encoded 


Element (FirstShowing) 





Optional element not encoded 


Element (LastShowing) 





Optional element not encoded 


Element (Free) 





Optional element not encoded 


} 






} 






} 






} 






} 






} 






} 







The content of the string buffer used by the dvbStringCodec for the above example is provided in table B.2. The 
characters are encoded according to UTF-8 and strings are terminated by a null terminator. 

Table B.2: Content of the string buffer used by the dvbStringCodec() (UTF-8 encoding assumed) 



String buffer content 


String offset 


Notes 


"dvb://1234..0001" 





Value of the servicelDRef 


"crid://1a2b3c4d" 


17 


GRID of the Program 


"Footle" 


33 


Title of the program 


"Kicking around a pig's bladder" 


40 


Synopsis of the program 
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Annex C (informative): 

Example TVA-init and Decoderlnit messages 

C.1 Example TVA-init message 

Table C.l is an example TVA-init message that conforms to the profile specified in the present document. 

Table C.1 : Example TVA-init message 



Field 


No. of bits 


Value 


Notes 


TVA-init { 








EncodingVersion 


8 


'OxFO' 


DVB profile of BiM 


IndexingFlag 


1 





No indexing used in the current TVA stream 


reserved 


7 


1111111 




Decoder Initptr 


8 


5 


Position of the decoderlnit data from the 
beginning of the TVA-init message 


{ 






/* EncodingVersion == 'OxFO'7 


BufferSizeFlag 


1 





default buffer size for the ZlibCodec is used 


PositionCodeFlag 


1 





position codes are not used 


reserved 


6 


111111 




CharacterEncoding 


8 


'0x01' 


UTF-8 Character Encoding 


} 








Reserved 


0or8+ 






Decoderlnit ( ) 


8+ 


[data] 


Decoder Initialization message 


} 









C.2 Example Decoderlnit message 

Table C.2 is an example Decoderlnit message that conforms to the profile specified in the present document. 

Table C.2: Example Decoderlnit message 



Field 


No. of bits 


Value 


Semantic 


Decoderlnit { 








Sys terns Prof ileLevellndi cat ion 


16 


'0x80' 


arbitrary value 


UnitSizeCode 


3 


000 


default unit size 


ReservedBits 


5 


11111 




NumberOf Schemas 


8 


'0x01' 


only one schema used: TV-Anytime 


{ 








SchemaURI_Length [0] 


8 


'0x15' 


21 characters in the URI string 


SchemaURI [0] 




"urn:tva:metadata:2004" 




LocationHint Length [0] 


8 


'0x00' 


no location hint is provided. 


NumberOf TypeCodecs [0] 


8 


'0x00' 


only default codecs are used 


} 








InitialDescription Length 


8 


'0x00' 


the initial root description is 
conveyed in the TVAMain fragment 


} 
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Annex D (informative): 

Example extension of the TVA Schema 

D.1 Example extended schema 

The following is an example schema that extends the TVA schema defined in TS 102 822-3-1 [4]. 



<?xml version="l . 0" encoding="UTF-8"?> 

<xs : schema targetNamespace="urn:extended_schema: 2 010" 

xmlns :xs="http: //www.w3 .org/2001/XMLSchema" 

xmlns :mpeg7="urn:mpeg:mpeg7 : schema: 2 001" 

xmlns : tva="urn: tva : metadata : 2 04 " 

xmlns= " urn : extended_s chema : 2 1 " 

elementFormDefault=" qualified" 

attributeFormDefault= "unqualified" > 

<!-- --> 

<!-- imports --> 

<!-- --> 

<xs : import namespace="urn:mpeg:mpeg7 : schema: 2 001" 

schemaLocation="mpeg7_tva.xsd"/> 
<xs : import namespace= "urn: tva : metadata : 2 04 " 

schemaLocation="tva_metadata_vl3_aml .xsd"/> 

<!-- --> 

<!-- TV-Anytime Extension --> 

<!-- --> 

<xs : complexType name="my_BasicContentDescriptionType"> 
<xs : annotation> 

<xs : documentation> 

This is the extension of the tva:BasicContentDescriptionType 
which allows to provide the URL of a Logo for the program. 
</xs :documentation> 
</xs : annotation> 
<xs : complexContent> 

<xs : extension base= " tva : BasicContentDescript ionType " > 
<xs : sequence> 

<element name="ProgramLogoURL" type="xs :anyURI" minOccurs="0"/> 
</xs : sequence> 
</xs : extension> 
</xs : complexContent> 
</xs : complexType> 
</xs : schema> 



D.2 Example Decoderlnit message for the extended 
schema 

As described in clause 9.4.4, forward compatibility main principle is to use the namespace of the schemata, i.e. the 
schemata URIs, as unique version identifiers. The identifiers are generated on the basis of URIs conveyed in the 

Decoderlnit. 
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Table D. 1 provides an example of Decoderlnit message for the extended TV-Anytime schema. 

Table D.1 : Example Decoderlnit Message for an extended schema 



Field 


No. Of 
bits 


Value 


Semantic 


Decoderlnit { 








Sys terns Prof ileLevel Indication 


16 


'0x80' 


arbitrary value 


UnitSizeCode 


3 


000 


default unit size 


ReservedBits 


5 


11111 




NumberOf Schemas 


8 


'0x02' 


two schemas are used: TV- 
Anytime schema, and the 
extended schema 


{ 








/* schema 0: TVA */ 








SchemaURI Length [0] 


8 


'0x15' 


21 characters in the URI string 


SchemaURI [0] 




"um:tva:metadata:2004" 




LocationHint Length [0] 


8 


'0x00' 


no location hint is provided 


NumberOf TypeCodecs [0] 


8 


'0x00' 


only default codecs are used 


/* schema 1: extension */ 








SchemaURI_Length [1] 


8 


'0x18' 


24 characters in the URI string 


SchemaURI [1] 




"urn:extended schema: 
2010" 




LocationHint Length [1] 


8 


'0x00' 


no location hint is provided. 


NumberOf TypeCodecs [1] 


8 


'0x00' 


only default codecs are used 


} 








InitialDescription Length 


8 


'0x00' 


the initial root description is 
conveyed in the TVAMain 
fragment 


} 









D.3 Example index XPaths for the extended schema 

Clause 9.4.2.2 defines how the signalling of schemas is used to define namespace prefixes for use in index XPaths. 

The following example XPath expressions describe an index of Programlnformation fragments indexed by the element 
ProgramLogoURL of the extended type my_BasicContentDescriptionType; 

Example fragment Xpath: 

/tva:TVAMain/tva:ProgramDescription/tva:ProgramInformationTable/tva:ProgramInformation 
Example field Xpath: 

/tva:BasicDescription/dl:ProgramLogoURL.text() 
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Annex E (informative): 

Example Scenarios for encoding of TVAJd running_status 

as carried in EIT-present 



E.1 Introduction 



The following examples illustrate possible usage of the running_status field for TVA_ids carried in a TVA_id 
descriptor delivered in an EIT present/following sub_table, as defined in clause 11. 2. 



E.2 Examples 
E.2.1 Example 1 

Figure E. 1 illustrates a particular Item of Content (Y) has a TVA_id associated with it whilst running. 



Item of Content: X 
Associated TVA Id: 0001 



Item of Content: Y 
Associated TVA Id: 0002 



TVA id: 0002 



^[Ru 



Figure E.1 : Example 1 



E.2.2 Example 2 



Figure E.2 illustrates a number of Items of Content have a TVAJd associated with them whilst running. 



Item of Content: X 
Associated TVA Id: 0001 



Item of Content: Y 
Associated TVA Id: 0002 



TVAJd: 0001 4 [Running 

TVAJd: 0002 

Figure E.2: Example 2 

E.2.3 Example 3 

Figure E.3 illustrates where start of Item of Content Y is preceded by associated TVAJd with state "Starts shortly". 
This may or may not overlap with the previous Item of Content (X). 



Item of Content: X 
Associated TVA Id: 0001 



Item of Content: Y 
Associated TVA Id: 0002 



TVAJd: 0001 ^jaiiiiii 

TVA id: 0002 



2 [Starts shortly] , 4 [Running 

Figure E.3: Example 3 
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E.2.4 Example 4 



In figure E.4, item of Content X overruns significantly compared to its scheduled start_time and duration. Dming the 
overrun the adjusted start_time for Item of Content Y may not yet be known and hence it may not be possible to update 
scheduled start_time. Transmitting the relevant TVA_id for Item of Content Y with the state "Not yet running" indicates 
that this content is still scheduled to be broadcast. 



Item of Content: X 
Associated TVA Id: 0001 



TVAJd: 0001 
TVA id: 0002 



4 [Running] 



1 [Not yet running] 



2 [Starts shortly] 



Most recent scheduled start_time 
for Item of Content Y that has 
been made available to the 
receiver, e.g. as broadcast in the 
relevant DVB locator. 
At the time of overrun of Item of 
Content X the adjusted start_time 
for Item of Content Y may not be 
known. 



Item of Content: Y 
Associated TVA Id: 0002 



4 [Running 



Actual startjime for 
Item of Content Y 



E.2.5 Example 5 



Figure E.4: Example 4 



In figure E.5, Item of Content X, e.g. a film, is split into two parts by Item of Content Y, e.g. a news flash. 



Item of Content: X, Part 1 
Associated TVA Id: 0001 



Item of Content: Y 
Associated TVA Id: 0002 



Item of Content: X, Part 2 
Associated TVA Id: 0001 



TVAJd: 0001 
TVA id: 0002 



4 [Running] 



3 [Paused] 



2 [Restarts shortly] 4 [Running 



2 [Starts shortly] 4- [Running] I 

Figure E.5: Example 5 
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Annex F (informative): 
Classification scheme encoding 



This annex describes the implementation of and the use of the dvbControlledTermCodec codec defined in the present 
document. 

As described in clause 9.4.3.7, this codec encodes a reference to a term defined in a classification scheme by encoding 
the ID of the classification scheme and the rank of the term within that scheme. 

In the case of the TVARoleCS classification scheme, one should note that the definition of the scheme begins by 
importing the terms of the RoleCS MPEG-7 classification scheme. This is equivalent to copying the definitions of all 
the terms in RoleCS into the beginning of the TVARoleCS. 

As a consequence, every term defined in the RoleCS, for example, is also defined in the TVARoleCS and can therefore 
be referenced by two different URIs (one referencing the RoleCS and the other the TVARoleCS). Care needs be taken 
when identifying the rank of terms defined in TVARoleCS but not imported from RoleCS because the imported terms 
are enumerated first. 

Table F.l illustrates this by providing the correct ranks for some of these terms. 

Table F.1 : Rank of terms defined in TVARoleCS and RoleCS classification schemes 



controlled term URI 


name 


Encoded 

Classification 

Scheme ID 


Encoded term 
rank 


urn:mpeg:mpeg7:cs:RoleCS:2001:AUTHOR 


Author 


0x0 D 





urn:mpeg:mpeg7:cs;RoleCS:2001:UNKNOWN 


Unknown 


0x0 D 


54 


urn:tva:metadata:cs:TVARoleCS:2004:AUTHOR 
(see note 1) 


Author 


0x0 E 





urn:tva:metadata:cs:TVARoleCS:2004:UNKNOWN 
(see note 1) 


Unknown 


0x0 E 


54 


urn:tva:metadata:cs:TVARoleCS:2004:V708 
(see note 2) 


Dubber 


0x0 E 


55 


urn:tva:metadata:cs:TVARoleCS:2004:V492 
(see note 2) 


Production Secretary 


OxOE 


143 


NOTE 1 : These terms are imported from the RoleCS. 

NOTE 2: These terms are defined in TVARoleCS but are ranked after imported terms. 
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Annex G (informative): 
Associating metadata with content 

The process of booking and acquiring an item of content will result in one or more CRIDs being associated with it 
within the receiver. When using any of these CRIDs to obtain metadata the following need to be considered: 

a) Metadata may be available from one or more metadata providers. 

b) The metadata available (from any metadata provider) may change over time. This could be for various reasons 
including fixing a spelling mistake, making the information more contextual (e.g. "the film features the late 
John Actor") or more targeted to a particular audience (e.g. "Check this out, its buff!"). 

c) Except where explicitly defined below, the metadata obtained from any metadata provider at any point in time 
is as valid as any other metadata that may be obtained using the same CRID at any other time and/or from any 
other metadata provider. Any metadata associated with a CRID needs to be created so that this is observed. If 
the nature of the use of a CRID is such that this cannot be guaranteed then no metadata should be associated 
with it. The exceptions to this are: 

1) Metadata supporting live segmentation. In this case the version of segmentation metadata most recently 
delivered is always more relevant to the current state of the content than the version of segmentation 
delivered previously. 

2) Metadata obtained using a CRID that has been identified as transient. See clause 5.2.2. 

d) Metadata obtained may identify other CRIDs (e.g. using the MemberOf element) that are not already 
associated with the item of content within the receiver. Such CRIDs may be used to obtain additional 
metadata. 

NOTE: Of course the metadata from one or other metadata provider may be more to the taste of a particular 
viewer and so may be individually perceived as more "relevant". Further, more recent versions of 
metadata may (by definition) be more up to date in terms of spelling, context and style. 

From the perspective of a receiver this means that: 

a) Metadata obtained at one point in time and stored within the receiver is still valid to use at some later time. 

b) Metadata need not be obtained and stored at the same time that the item of content is booked or acquired. 

c) It is left to the receiver to determine which metadata (obtained from which metadata provider and using which 
CRID) to present to the viewer. 

d) If there is no metadata available for a particular CRID then it may be necessary to resolve it within CRI until a 
CRID with associated metadata can be identified. 
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Annex H (informative): 

CRI Result Type Interpretation and Example Usage 

This annex describes all combinations of result_type, acquisition_flag and re_resolve_flag that can be signalled in the 
CRI result data structure defined in clause 7.3.2.3. Table H.l details the meaning and an example use for each 
combination. 

If the re_resolve_flag indicates "complete", all of the results for the CRID, as far as it is known by the broadcaster in 
their future scheduling window, are included or have been included in these results and previous incomplete results. 
Note that this does not mean that the results may not change in the future due to scheduling changes, especially if the 
results are locators. A flag value of "incomplete" means that additional results may be transmitted in the future. 

If "all" is specified in the acquisition_flag, all of the CRIDs or locators included in these results and all previous 
incomplete results for this CRID collectively make the content. A flag value of "any" is used when all of the CRIDs or 
locators in these results or previous incomplete results for this CRID are equally valid and refer to the same content. 

Table H. 1 describes the meaning of different combinations of result_type, acquisition_flag and re_resolve_flag. 

Table H.l : CRI Result Types 



result_type 


acquisition_flag 


re_resolve_flag 


Description 


Example use 


GRID to GRID 


All 


Gomplete 


All CRIDs included in these and 
previous incomplete results need 
to be resolved to obtain further 
results. No more results to follow. 


Whole series or group. 


GRID to GRID 


All 


Incomplete 


All CRIDs included in these and 
previous incomplete results and 
future results up to and including 
the next complete result need to 
be resolved to obtain further 
results. More results may follow. 


Ongoing series or fixed-term 
series where resolution 
provider as yet unable or 
unwilling to provide all group 
members. 


GRID to GRID 


Any 


Gomplete 


Any one GRID included in these 
or previous incomplete results 
needs to be resolved to obtain 
further results. No more results to 
follow. 


Different way of describing 
alternative instances. 


GRID to GRID 


Any 


Incomplete 


Any one CRID included in these 
or previous incomplete results or 
in any future results up to and 
including the next complete result 
needs to be resolved to obtain 
further results. More results may 
follow. 


Different way of describing 
alternative instances. 


GRID to 
locator 


All 


Gomplete 


All items included in these and 
previous incomplete results need 
to be acquired before content 
complete. No more results to 
follow. 


A film split in two by the 
news. 


GRID to 
locator 


All 


Incomplete 


All items included in these and 
previous incomplete results plus 
items in future results up to and 
including the next complete result 
need to be acquired before 
content complete. More results 
may follow. 


Not normally used. 
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result_type 


acquisition_flag 


re_resolve flag 


Description 


Example use 


GRID to 
locator 


Any 


Gomplete 


Any one item included in these or 
previous incomplete results 
needs to be acquired. No more 
results to follow. 


Programme with defined 
transmission location(s). 


GRID to 
locator 


Any 


Incomplete 


Any one item included in these or 
previous incomplete results or in 
future results up to and including 
the next complete result needs to 
be acquired. More results may 
follow. 


Programme where 
transmission location not yet 
defined or additional 
transmission locations are 
anticipated. 



Where resolution is marked as complete, any future results for a CRID supersede all previous results. 

The acquisition status of an incomplete result remains unchanged up to and including the next complete result. 

In the case where a group CRID resolves to a "complete" set of CRID results, this does not imply that the broadcast 
locations of all the CRIDs in the group need be provided. It is only necessary that the group membership be provided, 
i.e. each of the CRIDs in the results data resolved from the group CRID may not yet be resolvable. 

The reresolve time and date, where provided, indicates the earliest time at which any further resolution information will 
be broadcast. This information will be provided where the broadcaster knows that the content will be broadcast in the 
future but that this date is currently outside its scheduling window. The reresolve date will generally be when the 
broadcaster anticipates that this broadcast time moves into its scheduling window hence when it will be able to provide 
the resolution information. 

If a locator is provided in the results, the broadcaster may modify the form and / or value of the locator at any time up to 
the end of transmission of the content. 
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